我可以简化调用javascript函数的方式吗?

时间:2012-02-07 15:07:43

标签: jquery

我有以下内容,我在许多屏幕上执行内联:

tinyMCE.init({
    // General options
    mode : "specific_textareas",
    editor_selector : "mceEditor",
    theme: "advanced",
    plugins: "autolink,lists,spellchecker,pagebreak,style,layer,table,save,advhr,advimage,advlink,emotions,iespell,inlinepopups,insertdatetime,preview,media,searchreplace,print,contextmenu,paste,directionality,fullscreen,noneditable,visualchars,nonbreaking,xhtmlxtras,template",

    // Theme options
    theme_advanced_buttons1: "save,newdocument,|,bold,italic,underline,strikethrough,|,justifyleft,justifycenter,justifyright,justifyfull,|,styleselect,formatselect,fontselect,fontsizeselect",
    theme_advanced_buttons2: "cut,copy,paste,pastetext,pasteword,|,search,replace,|,bullist,numlist,|,outdent,indent,blockquote,|,undo,redo,|,link,unlink,anchor,image,cleanup,help,code,|,insertdate,inserttime,preview,|,forecolor,backcolor",
    theme_advanced_buttons3: "tablecontrols,|,hr,removeformat,visualaid,|,sub,sup,|,charmap,emotions,iespell,media,advhr,|,print,|,ltr,rtl,|,fullscreen",
    theme_advanced_buttons4: "insertlayer,moveforward,movebackward,absolute,|,styleprops,spellchecker,|,cite,abbr,acronym,del,ins,attribs,|,visualchars,nonbreaking,template,blockquote,pagebreak,|,insertfile,insertimage",
    theme_advanced_toolbar_location: "top",
    theme_advanced_toolbar_align: "left",
    theme_advanced_statusbar_location: "bottom",
    theme_advanced_resizing: true,

    // Skin options
    skin: "o2k7",
    skin_variant: "silver",

    // Example content CSS (should be your site CSS)
    content_css: "css/example.css",

    // Drop lists for link/image/media/template dialogs
    template_external_list_url: "js/template_list.js",
    external_link_list_url: "js/link_list.js",
    external_image_list_url: "js/image_list.js",
    media_external_list_url: "js/media_list.js",

    // Replace values for the template plugin
    template_replace_values: {
        username: "Some User",
        staffid: "991234"
    }
});

我想把它移到一个文件然后调用它。有一种简单的方法可以做到这一点吗?

2 个答案:

答案 0 :(得分:1)

base.js

window.pageinit = function(){

    tinyMCE.init({

        /* ... your initialization code ... */

    });
}

在引用base.js的页面中:

<script type="text/javascript">

    pageinit();

</script>

答案 1 :(得分:1)

Xander的回答类似,但我只会全局存储选项对象。

window.tinyMCEOptions = {
    // General options
    mode : "specific_textareas",
    /* Your other options here.
     * Store in your favorite .js file and link your page to it.
     */
}

然后拨打tinyMCE.init,如:

tinyMCE.init(window.tinyMCEOptions);

这样做的好处是它可以让您轻松更改选项:

window.tinyMCEOptions.content_css: 'css/different.css'
tinyMCE.init(window.tinyMCEOptions);