「MediaWiki:Common.js」修訂間的差異

出自宅犬維基
跳至導覽 跳至搜尋
(新頁面: →‎所有用戶在加載任何頁面時,這裡的JavaScript都會加載 == 輔助處理 == //功能設定 var JSConfig={ //showBarA:(wgUserName == null),//設定JS Anonnotice的匿...
 
 
(未顯示同一使用者於中間所作的 9 次修訂)
行 1: 行 1:
/*
+
/* Any JavaScript here will be loaded for all users on every page load. */
所有用戶在加載任何頁面時,這裡的JavaScript都會加載
 
  
== 輔助處理 ==
+
// <syntax type="javascript">
*/
+
 
//功能設定
+
    /**  
var JSConfig={
+
        Toggles the display of elements on a page
//showBarA:(wgUserName == null),//設定JS Anonnotice的匿名出現條件
+
        Author/contact: Austin Che http://openwetware.org/wiki/User:Austin_J._Che
//showBarU:false,//設定登入用戶使用JS Anonnotice的開關
+
        See http://openwetware.org/wiki/OpenWetWare:Toggle for examples and documentation
isEdit0:true, //設置是否顯示編輯首段按鈕
+
    */
editSectionLink:'right',//設置編輯按鈕是否在右側
+
 
collapseText:wgULS('隱藏▲','隱藏▲'),//指示折疊收縮的默認文字
+
// indexed array of toggler ids to array of associated toggle operations
expandText:wgULS('顯示▼','顯示▼'),//指示折疊展開的默認文字
+
// each operation is a two element array, the first being the type, the second a class name or array of elements
autoCollapse:2,  //文章少於 autoCollapse 個折疊塊時,不自動折疊
+
// operation types are strings like "_reset" or "" for the default toggle operation
}
+
var togglers = new Array();   
// 兼容性修正
+
var allClasses = new Object(); // associative map of class names to page elements
if (document.attachEvent && document.compatMode && document.compatMode == "CSS1Compat")
+
 
 +
function toggler(id)
 
{
 
{
var oldWidth;
+
    var toBeToggled = togglers[id];
var docEl = document.documentElement;
+
    if (!toBeToggled)
 +
        return;
  
function fixIEScroll()
+
    // if some element is in list more than once, it will be toggled multiple times
{
+
    for (var i = 0; i < toBeToggled.length; i++)
if (!oldWidth || docEl.clientWidth > oldWidth){
+
    {
doFixIEScroll();
+
        // get array of elements to operate on
}else{
+
        var toggles = toBeToggled[i][1];
setTimeout(doFixIEScroll, 1);
+
        if (typeof(toggles) == "string")
}
+
        {
oldWidth = docEl.clientWidth;
+
            if (toggles.charAt(0) == '-')
}
+
            {
 +
                // treat as an element ID, not as class
 +
                toggles = document.getElementById(toggles.substring(1));
 +
                if (toggles)
 +
                    toggles = new Array(toggles);
 +
            }
 +
            else
 +
                toggles = allClasses[toggles];
 +
        }
 +
        if (!toggles || !toggles.length)
 +
            continue;
  
function doFixIEScroll() {
+
        var op = toBeToggled[i][0]; // what the operation will be
docEl.style.overflowX = (docEl.scrollWidth - docEl.clientWidth < 4) ? "hidden" : "";
 
}
 
  
document.attachEvent("onreadystatechange", fixIEScroll);
+
        switch (op)
attachEvent("onresize", fixIEScroll);
+
        {
 +
            case "_reset":
 +
                for (var j = 0; j < toggles.length; j++)
 +
                    toggles[j].style.display = toggles[j]._toggle_original_display;
 +
                break;
 +
            case "_show":
 +
                for (var j = 0; j < toggles.length; j++)
 +
                    toggles[j].style.display = '';
 +
                break;
 +
            case "_hide":
 +
                for (var j = 0; j < toggles.length; j++)
 +
                    toggles[j].style.display = 'none';
 +
                break;
 +
            case "":
 +
            default:
 +
                // Toggle
 +
                for (var j = 0; j < toggles.length; j++)
 +
                    toggles[j].style.display = ((toggles[j].style.display == 'none') ? '' : 'none');
 +
                break;
 +
        }
 +
    }
 
}
 
}
  
// 移動元素
+
function createTogglerLink(toggler, id)
function elementMoveto(node, refNode, pos){//默認位置為refNode前
+
{
if(node && refNode){
+
    var toggle = document.createElement("a");
var parent=refNode.parentNode;
+
    toggle.className = 'toggler-link';
if (pos && pos=='after') {refNode=refNode.nextSibling;}
+
    toggle.setAttribute('id', 'toggler' + id);
try {
+
    toggle.setAttribute('href', 'javascript:toggler("' + id + '");');
if(refNode){
+
    var child = toggler.firstChild;
parent.insertBefore(node, refNode);
+
    toggler.removeChild(child);
}else{
+
    toggle.appendChild(child);
parent.appendChild(node);
+
    toggler.insertBefore(toggle, toggler.firstChild);
}
 
} catch (DOMException) {};
 
}
 
}
 
//創建元素
 
function createElement(tag,children,props){
 
var element = document.createElement(tag);
 
if(!(children instanceof Array)){children=[children];}
 
for(var i=0;i<children.length;i++){
 
var child=children[i];
 
if(typeof child=='string'){child=document.createTextNode(child);}
 
if(child){element.appendChild(child);}
 
}
 
if(typeof props=='object'){
 
for(var k in props){
 
switch(k){
 
case 'styles':
 
var styles=props.styles;
 
for(var s in styles){element.style[s]=styles[s];}
 
break;
 
case 'events':
 
var events=props.events;
 
for(var e in events){ addHandler(element,e,events[e]); }
 
break;
 
case 'class':
 
element.className=props[k];break;
 
default:
 
element.setAttribute(k,props[k]);
 
}
 
}
 
}
 
return element;
 
 
}
 
}
  
 +
function toggleInit()
 +
{
 +
    var togglerElems = new Array();
 +
    var toggleGroup = new Array();
  
 +
    // initialize/clear any old information
 +
    togglers = new Array();   
 +
    allClasses = new Object();
 +
       
 +
    // make list of all document classes
 +
    var elems = document.getElementsByTagName("*");
 +
    var numelems = elems.length;
 +
    for (var i = 0; i < elems.length; i++)
 +
    {
 +
        var elem = elems[i];
 +
        if (!elem.className)
 +
            continue;
  
//JS、CSS導入模塊
+
        elem._toggle_original_display = elem.style.display;
function importScript( page ) {
+
        var togglerID = -1;
var src= /^https?:\/\//.test(page) ? page : getWikiPath(page,{'ctype':'text/javascript'});
+
        var elemClasses = elem.className.split(' '); // get list of classes
var scriptElem = createElement( 'script',null,{'src':src,'type':'text/javascript'} );
+
        for (var j = 0; j < elemClasses.length; j++)
document.getElementsByTagName( 'head' )[0].appendChild( scriptElem );
+
        {
}
+
            var elemClass = elemClasses[j];
function importStylesheet( page ) {
+
            if (! allClasses[elemClass])
var sheet= /^https?:\/\//.test(page) ? page : getWikiPath(page,{'ctype':'text/css'});
+
                allClasses[elemClass] = new Array();
var styleElem = createElement( 'style', ['@import "'+sheet+'";'], {'type':'text/css'} );
+
            allClasses[elemClass].push(elem);
document.getElementsByTagName( 'head' )[0].appendChild( styleElem );
 
}
 
  
 +
            // all the special classes begin with _toggle
 +
            if (elemClass.substring(0, 7) != "_toggle")
 +
                continue;
  
 +
            if (elemClass == "_togglegroup")
 +
                toggleGroup = new Array();
 +
            else if (elemClass == "_toggle")
 +
                toggleGroup.push(elem);
 +
            else if (elemClass.substring(0, 12) == "_toggle_init")
 +
            {
 +
                // set initial value for display (ignore the original CSS set value)
 +
                // understands _toggle_initshow and _toggle_inithide
 +
                var disp = elemClass.substring(12);
 +
                if (disp == "show")
 +
                    elem.style.display = '';
 +
                else if (disp == "hide")
 +
                    elem.style.display = 'none';
 +
                elem._toggle_original_display = disp;
 +
            }
 +
            else if (elemClass.substring(0, 8) == "_toggler")
 +
            {
 +
                if (togglerID == -1)
 +
                {
 +
                    togglerID = togglers.length;
 +
                    togglers[togglerID] = new Array();
 +
                    togglerElems[togglerID] = elem;
 +
                }
  
== 段落編輯連結 ==
+
                // all classes are of form _toggler_op-CLASS
*/
+
                // figure out what class we're toggling
//JSConfig.isEdit0 設置是否出現「編輯首段」按鈕
+
                // if none is specified, then we use the current toggle group
//對不需要編輯首段的頁面,還可在頁面中加 Template:NoEdit 模板來禁用。
+
                var toBeToggled;
//JSConfig.editSectionLink 設置「編輯」按鈕的位置
+
                var hyphen = elemClass.indexOf('-');
if (wgIsArticle && wgAction == "view") {
+
                if (hyphen != -1)
//增加編輯首段按鈕
+
                    toBeToggled = elemClass.substring(hyphen+1);
addOnloadHook(function(){
+
                else
if(!JSConfig.isEdit0||(document.getElementById&&document.getElementById('no-edit-0'))){return;}
+
                {
var caEdit=document.getElementById&&document.getElementById('ca-edit');
+
                    toBeToggled = toggleGroup;
if (!caEdit){return;}
+
                    hyphen = elemClass.length;
var linkAttributes={
+
                }
'href':caEdit.firstChild.href + '&section=0',
 
'title':wgULS('編輯正文所有標題之前的文字(通常稱為首段或導言)','編輯正文所有標題之前的文字(通常稱首段或導言)'),
 
'accesskey':'0'
 
}
 
  
//增加0按鈕標籤
+
                var op = elemClass.substring(8, hyphen);
var caEdit0 = createElement(
+
                togglers[togglerID].push(new Array(op, toBeToggled));
'li',
+
            }
[createElement('A',['0'],linkAttributes)],
+
        }
{id:'ca-edit-0'}
+
    }
);
 
caEdit.className = 'istalk';
 
elementMoveto(caEdit0,caEdit,"after");
 
  
//增加條目標題下的「編輯首段」按鈕
+
    // add javascript links to all toggler elements
var editsection0= createElement(
+
    for (var i = 0; i < togglerElems.length; i++)
'span',
+
        createTogglerLink(togglerElems[i], i);
['[',createElement('A',[wgULS('編輯首段','編輯首段')],linkAttributes),']'],
 
{'class':'editsection'}
 
);
 
var siteSub=document.getElementById&&document.getElementById('siteSub');
 
elementMoveto( editsection0 , siteSub.firstChild );
 
});
 
 
//設置編輯按鈕位置是否浮動
 
addOnloadHook(function(){
 
if (JSConfig.editSectionLink=='right') { return; }
 
var editLinks=getElementsByClassName(document.getElementById('bodyContent'),"span","editsection");
 
for(var i = 0; i < editLinks.length; i++) {
 
editLinks[i].style.cssFloat = editLinks[i].style.float = 'none';
 
editLinks[i].style.textAlign = "left" ;
 
editLinks[i].parentNode.appendChild(editLinks[i]);
 
}
 
});
 
 
}
 
}
  
/*
 
  
== 增加折疊功能 ==
+
function owwsitesearch(f){
*/
+
    f.q.value='site:http://openwetware.org/wiki/'+
/** 折疊 div table *****************************
+
        f.base.value+'++'+f.qfront.value
*  Description: 實現div.NavFrame和table.collapsible的可折疊性。
+
}
*  JSConfig的collapseText、expandText、autoCollapse屬性定義默認文字和默認最少自動折疊塊
 
*  Maintainers: User:fdcn
 
*/
 
addOnloadHook(function(){
 
function toggleState(item){
 
var oldState=item.state;
 
item.state=1-oldState;
 
if(item.text[0]){
 
item.text[oldState].style.display = 'inline';
 
item.text[item.state].style.display='none';
 
}
 
item.action(item);
 
}
 
 
 
function cancelBubble(e){
 
e=e||window.event;
 
if(e.stopPropagation){e.stopPropagation();}else{e.cancelBubble=true;}
 
}
 
function createToggleButton(head,frame,toggle){
 
var textS,textH;
 
var button=getElementsByClassName(head,"span","NavToggle")[0];
 
if(button){
 
textS=getElementsByClassName(button,"span","NavToggleShow")[0]
 
textH=getElementsByClassName(button,"span","NavToggleHide")[0];
 
}else {
 
textS=createElement("span",[JSConfig.expandText]);
 
textH=createElement('span',[JSConfig.collapseText]);
 
button=createElement("span",[textS,textH],{'class':"NavToggle",styles:{'width':"3.8em"}});
 
}
 
if(textS){textS.style.display='none';}
 
button.style.display='inline';
 
var item={'state':0, 'text':[textS,textH],'frame':frame,'action':toggle}
 
 
 
var links=head.getElementsByTagName("A");
 
for(var i=0,l;l=links[i];i++){ addClickHandler(l,cancelBubble); }
 
 
head.insertBefore( button, head.childNodes[0] );
 
head.style.cursor = "pointer";
 
addClickHandler( head, function(){toggleState(item);} );
 
return item;
 
}
 
 
// 折疊div
 
function toggleNavigationBar(item)
 
{
 
var cls=item.state?'none':'block';
 
for (
 
var NavChild = item.frame.firstChild;
 
NavChild != null;
 
NavChild = NavChild.nextSibling
 
){
 
if (NavChild.className == 'NavPic' || NavChild.className == 'NavContent') {
 
NavChild.style.display = cls;
 
}
 
}
 
}
 
 
// 折疊表格
 
function collapseTable( item )
 
{
 
var rows = item.frame.getElementsByTagName( "tr" );
 
var display = item.state? 'none':rows[0].style.display;
 
for (var i=1,row; row=rows[i]; i++) { row.style.display = display; }
 
}
 
 
//init
 
var item,items=[];
 
var NavFrames=getElementsByClassName(document,"div","NavFrame");
 
for(var i=0,NavFrame;NavFrame = NavFrames[i];i++) {
 
var heads=getElementsByClassName(NavFrame,"div","NavHead");
 
for(var ih=0,head; head = heads[ih]; ih++ ) {
 
if (head.parentNode != NavFrame) {continue;}
 
items.push(createToggleButton(head,NavFrame,toggleNavigationBar));
 
break;
 
}
 
}
 
 
 
var tables = getElementsByClassName(document,"table","collapsible");
 
for ( var i = 0,table; table= tables[i]; i++ ) {
 
var head = table.getElementsByTagName( "tr" )[0].getElementsByTagName( "th" )[0];
 
items.push(createToggleButton(head,table,collapseTable));
 
}
 
 
 
var count=items.length;
 
for ( var i = 0;  i<count; i++ ) {
 
item=items[i];
 
if ( hasClass( item.frame, "collapsed" ) || ( count >= JSConfig.autoCollapse && hasClass( item.frame, "autocollapse" ) ) ) {
 
toggleState(item);
 
}
 
}
 
});
 
 
 
//修正折疊後定位變化
 
hookEvent("load",function(){if(location.hash){location.href=location.hash;}});
 
 
 
/*
 
  
  
==Anonnotice顯示==
+
addOnloadHook(toggleInit);
  
*/
+
// </syntax>
/** anonnotice for IP user **************************
 
  *
 
  * Maintainced by Alexsh@zhwiki, PhiLiP@zhwiki
 
  */
 
addOnloadHook(function(){
 
document.writeln('<div style="position:absolute; z-index:40; left:155px; top:0px; clear:both; float:left;text-align:left; margin:0 auto;" id="donate">'+ ( wgUserName ? JSConfig.siteNotice : JSConfig.blockMsg )+'</div>');
 
});
 

於 2013年6月13日 (四) 11:12 的最新修訂

/* Any JavaScript here will be loaded for all users on every page load. */

// <syntax type="javascript">

    /** 
        Toggles the display of elements on a page 
        Author/contact: Austin Che http://openwetware.org/wiki/User:Austin_J._Che
        See http://openwetware.org/wiki/OpenWetWare:Toggle for examples and documentation
     */

// indexed array of toggler ids to array of associated toggle operations
// each operation is a two element array, the first being the type, the second a class name or array of elements
// operation types are strings like "_reset" or "" for the default toggle operation
var togglers = new Array();     
var allClasses = new Object(); // associative map of class names to page elements

function toggler(id)
{
    var toBeToggled = togglers[id];
    if (!toBeToggled)
        return;

    // if some element is in list more than once, it will be toggled multiple times
    for (var i = 0; i < toBeToggled.length; i++)
    {
        // get array of elements to operate on
        var toggles = toBeToggled[i][1];
        if (typeof(toggles) == "string")
        {
            if (toggles.charAt(0) == '-')
            {
                // treat as an element ID, not as class
                toggles = document.getElementById(toggles.substring(1));
                if (toggles)
                    toggles = new Array(toggles);
            }
            else
                toggles = allClasses[toggles];
        }
        if (!toggles || !toggles.length)
            continue;

        var op = toBeToggled[i][0]; // what the operation will be

        switch (op)
        {
            case "_reset":
                for (var j = 0; j < toggles.length; j++)
                    toggles[j].style.display = toggles[j]._toggle_original_display;
                break;
            case "_show":
                for (var j = 0; j < toggles.length; j++)
                    toggles[j].style.display = '';
                break;
            case "_hide":
                for (var j = 0; j < toggles.length; j++)
                    toggles[j].style.display = 'none';
                break;
            case "":
            default:
                // Toggle
                for (var j = 0; j < toggles.length; j++)
                    toggles[j].style.display = ((toggles[j].style.display == 'none') ? '' : 'none');
                break;
        }
    }
}

function createTogglerLink(toggler, id)
{
    var toggle = document.createElement("a");
    toggle.className = 'toggler-link';
    toggle.setAttribute('id', 'toggler' + id);
    toggle.setAttribute('href', 'javascript:toggler("' + id + '");');
    var child = toggler.firstChild;
    toggler.removeChild(child);
    toggle.appendChild(child);
    toggler.insertBefore(toggle, toggler.firstChild);
}

function toggleInit()
{
    var togglerElems = new Array();
    var toggleGroup = new Array();

    // initialize/clear any old information
    togglers = new Array();     
    allClasses = new Object();
        
    // make list of all document classes
    var elems = document.getElementsByTagName("*");
    var numelems = elems.length;
    for (var i = 0; i < elems.length; i++)
    {
        var elem = elems[i];
        if (!elem.className)
            continue;

        elem._toggle_original_display = elem.style.display;
        var togglerID = -1;
        var elemClasses = elem.className.split(' '); // get list of classes
        for (var j = 0; j < elemClasses.length; j++)
        {
            var elemClass = elemClasses[j];
            if (! allClasses[elemClass])
                allClasses[elemClass] = new Array();
            allClasses[elemClass].push(elem);

            // all the special classes begin with _toggle
            if (elemClass.substring(0, 7) != "_toggle")
                continue;

            if (elemClass == "_togglegroup")
                toggleGroup = new Array();
            else if (elemClass == "_toggle")
                toggleGroup.push(elem);
            else if (elemClass.substring(0, 12) == "_toggle_init")
            {
                // set initial value for display (ignore the original CSS set value)
                // understands _toggle_initshow and _toggle_inithide
                var disp = elemClass.substring(12);
                if (disp == "show")
                    elem.style.display = '';
                else if (disp == "hide")
                    elem.style.display = 'none';
                elem._toggle_original_display = disp;
            }
            else if (elemClass.substring(0, 8) == "_toggler")
            {
                if (togglerID == -1)
                {
                    togglerID = togglers.length;
                    togglers[togglerID] = new Array();
                    togglerElems[togglerID] = elem;
                }

                // all classes are of form _toggler_op-CLASS
                // figure out what class we're toggling
                // if none is specified, then we use the current toggle group
                var toBeToggled;
                var hyphen = elemClass.indexOf('-');
                if (hyphen != -1)
                    toBeToggled = elemClass.substring(hyphen+1);
                else
                {
                    toBeToggled = toggleGroup;
                    hyphen = elemClass.length;
                }

                var op = elemClass.substring(8, hyphen);
                togglers[togglerID].push(new Array(op, toBeToggled));
            }
        }
    }

    // add javascript links to all toggler elements
    for (var i = 0; i < togglerElems.length; i++)
        createTogglerLink(togglerElems[i], i);
}


function owwsitesearch(f){
    f.q.value='site:http://openwetware.org/wiki/'+
        f.base.value+'++'+f.qfront.value
}


addOnloadHook(toggleInit);

// </syntax>