欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

JavaScript 常用函數(shù)庫詳解

 更新時間:2009年10月21日 15:04:53   作者:  
在WEB開發(fā)中,javascript提供了許多函數(shù)供開發(fā)人員使用,這些函數(shù)在Ajax流行前足夠了,但要構建一個交互性強些的應用恐怕就麻煩了。
為此,收集了自己平時常用到一些JavaScript函數(shù),它們在其它的JS庫也常見,現(xiàn)在整理并附上注釋,方便查閱,希望對大家有所幫助。
注:假設以下所有函數(shù)都放在一個CC對象中,方便引用。
復制代碼 代碼如下:

//這個方法相信是最常用的了,
//它雖然沒有選擇器那么強大,但也有個小增強版,可查指定結點下ID所在的子元素
function $(id, p) {
//id是否是字符串,還是一個HTML結點
var iss = id instanceof String || typeof id == "string";
if (iss && !p)
return document.getElementById(id);
//如果是結點的話就直接返回該結點
if(!iss)
return id;
//如果id與p是同一個元素,直接返回
if(p.id == id)
return p;
//往父結點搜索
var child = p.firstChild;
while (child) {
if (child.id == id)
return child;
//遞歸搜索
var v = this.$(id, child);
if (v)
return v;
child = child.nextSibling;
}
//的確找不到就返回null
return null;
}

復制代碼 代碼如下:

each: function(object, callback, args) {
if (!object) {
return object;
}
if (args) {
if (object.length === undefined) {
for (var name in object)
if (callback.apply(object[name], args) === false) break;
} else for (var i = 0, length = object.length; i < length; i++)
if (callback.apply(object[i], args) === false) break;
} else {
if (object.length == undefined) {
for (var name in object)
if (callback.call(object[name], name, object[name]) === false) break;
} else for (var i = 0, length = object.length, value = object[0];
i < length && callback.call(value, i, value) !== false;
value = object[++i]) {}
}
return object;
}

復制代碼 代碼如下:

//數(shù)組
function isArray(obj) {
return (typeof obj === "array" || obj instanceof Array);
},
//字符串
function isString(obj) {
return (typeof obj === "string" || obj instanceof String);
},
//函數(shù)
function isFunction(obj) {
return (typeof obj === "function" || obj instanceof Function);
},
//數(shù)字類型
function isNumber(ob) {
return (typeof ob === "number" || ob instanceof Number );
}

復制代碼 代碼如下:

// 返回表單可提交元素的提交字符串.
// 例如
// <form>
// <input type="text" name="user" value="rock" />
// <input type="text" name="password" value="123" />
// </form>
// 調用后就返回 user=rock&password=123
// 這些數(shù)據(jù)已經(jīng)過encodeURIComponent處理,對非英文字符友好.
// form元素中如果沒有name,則以id作為提供字符名.
function formQuery(f){
// f,一個Form表單.
var formData = "", elem = "", f = CC.$(f);
var elements = f.elements;
var length = elements.length;
for (var s = 0; s < length; ++s) {
elem = elements[s];
if (elem.tagName == 'INPUT') {
if ( (elem.type == 'radio' || elem.type == 'checkbox') && !elem.checked) {
continue;
}
}
if (formData != "") {
formData += "&";
}
formData += encodeURIComponent(elem.name||elem.id) + "="
+ encodeURIComponent(elem.value);
}
return formData;
}

復制代碼 代碼如下:

/**
* 移除數(shù)組指定元素.
* 參數(shù)既可傳遞一個整形下標,也可傳遞一個數(shù)組數(shù)據(jù).
*/
Array.prototype.remove = (function(p) {
//參數(shù)為下標
if (CC.isNumber(p)) {
if (p < 0 || p >= this.length) {
throw "Index Of Bounds:" + this.length + "," + p;
}
this.splice(p, 1)[0];
return this.length;
}
//參數(shù)為數(shù)組數(shù)據(jù),最終要找到下標來操作
if (this.length > 0 && this[this.length - 1] == p) {
this.pop();
} else {
var pos = this.indexOf(p);
if (pos != -1) {
this.splice(pos, 1)[0];
}
}
return this.length;
});

復制代碼 代碼如下:

Array.prototype.indexOf = (function(obj) {
for (var i = 0, length = this.length; i < length; i++) {
if (this[i] == obj) return i;
}
return - 1;
});

復制代碼 代碼如下:

/**
* 萬能而簡單的表單驗證函數(shù),這個函數(shù)利用了JS動態(tài)語言特性,看上去很神秘,
* 實際是很形象的,查看個例子就清楚了.
*/
validate: function() {
var args = CC.$A(arguments),
form = null;
//form如果不為空元素,應置于第一個參數(shù)中.
if (!CC.isArray(args[0])) {
form = CC.$(args[0]);
args.remove(0);
}
//如果存在設置項,應置于最后一個參數(shù)中.
//cfg.queryString = true|false;
//cfg.callback = function
//cfg.ignoreNull
//nofocus:true|false
var b = CC.isArray(b) ? {}: args.pop(),
d;
var queryStr = b.queryString,
ignoreNull = b.ignoreNull,
cb = b.callback;
var result = queryStr ? '': {};
CC.each(args,
function(i, v) {
//如果在fomr中不存在該name元素,就當id來獲得
var obj = v[0].tagName ? v[0] : form ? form[v[0]] : CC.$(v[0]);
//console.debug('checking field:',v, 'current value:'+obj.value);
var value = obj.value,
msg = v[1],
d = CC.isFunction(v[2]) ? v[3] : v[2];
//選項
if (!d || typeof d != 'object') d = b;
//是否忽略空
if (!d.ignoreNull && (value == '' || value == null)) {
//如果不存在回調函數(shù),就調用alert來顯示錯誤信息
if (!d.callback) CC.alert(msg, obj, form);
//如果存在回調,注意傳遞的三個參數(shù)
//msg:消息,obj:該結點,form:對應的表單,如果存在的話
else d.callback(msg, obj, form);
//出錯后是否聚集
if (!d.nofocus) obj.focus();
result = false;
return false;
}
//自定義驗證方法
if (CC.isFunction(v[2])) {
var ret = v[2](value, obj, form);
var pass = (ret !== false);
if (CC.isString(ret)) {
msg = ret;
pass = false;
}
if (!pass) {
if (!d.callback) CC.alert(msg, obj, form);
//同上
else d.callback(msg, obj, form);
if (!d.nofocus) obj.focus();
result = false;
return false;
}
}
//如果不設置queryString并通過驗證,不存在form,就返回一個對象,
//該對象包含形如{elementName|elementId:value}的數(shù)據(jù).
if (queryStr && !form) {
result += (result == '') ?
((typeof obj.name == 'undefined' || obj.name == '') ? obj.id: obj.name) +
'=' + value: '&' + v[0] + '=' + value;
} else if (!form) {
result[v[0]] = value;
}
});
//如果設置的queryString:true并通過驗證,就返回form的提交字符串.
if (result !== false && form && queryStr) result = CC.formQuery(form);
return result;
}

復制代碼 代碼如下:

/**
* 應用對象替換模板內容
* templ({name:'Rock'},'<html><title>{name}</title></html>');
* st:0,1:未找到屬性是是否保留
*/
templ: function(obj, str, st) {
return str.replace(/\{([\w_$]+)\}/g, function(c, $1) {
var a = obj[$1];
if (a === undefined || a === null) {
if (st === undefined) return '';
switch (st) {
case 0:
return '';
case 1:
return $1;
default:
return c;
}
}
return a;
});
}

相關文章

  • js右下角彈出提示框示例代碼

    js右下角彈出提示框示例代碼

    這篇文章主要介紹了js右下角彈出提示框示例代碼,即網(wǎng)頁右下角彈出廣告信息框實例代碼,感興趣的小伙伴們可以參考一下
    2016-01-01
  • Bootstrap 實現(xiàn)表格樣式、表單布局的實例代碼

    Bootstrap 實現(xiàn)表格樣式、表單布局的實例代碼

    這篇文章主要介紹了Bootstrap 實現(xiàn)表格樣式、表單布局的實例代碼,需要的朋友可以參考下
    2018-12-12
  • js獲取對象、數(shù)組的實際長度,元素實際個數(shù)的實現(xiàn)代碼

    js獲取對象、數(shù)組的實際長度,元素實際個數(shù)的實現(xiàn)代碼

    下面小編就為大家?guī)硪黄猨s獲取對象、數(shù)組的實際長度,元素實際個數(shù)的實現(xiàn)代碼。小編覺得挺不錯的,現(xiàn)在就分享 給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2016-06-06
  • js讓一行頁腳保持在底部

    js讓一行頁腳保持在底部

    所謂保持在底部就是: 在內容不超過一屏的情況下, 當瀏覽器窗口變小那行頁腳文字會跟著向上浮動但還是保持在底部。當內容多出一屏時,他顯示在網(wǎng)頁的最下邊,而不是窗口的最下邊;
    2008-04-04
  • 如何解決hover在ie6中的兼容性問題

    如何解決hover在ie6中的兼容性問題

    本篇主要分享了如何解決hover在ie6中的兼容性問題的方法,希望會對大家學習javascript有所幫助
    2016-12-12
  • js修改原型的屬性使用介紹

    js修改原型的屬性使用介紹

    原型(prototype)定義了特定類型的所有實例都可以訪問的屬性和方法,很多些情況下需要重新對原型中的屬性賦值,下面為大家介紹下如何修改原型
    2014-01-01
  • 深入淺析JavaScript中with語句的理解

    深入淺析JavaScript中with語句的理解

    JavaScript 有個 with 關鍵字, with 語句的原本用意是為逐級的對象訪問提供命名空間式的速寫方式。這篇文章主要介紹了JavaScript中with語句的相關知識,感興趣的朋友一起學習吧
    2016-05-05
  • JS實現(xiàn)禁止鼠標右鍵的功能

    JS實現(xiàn)禁止鼠標右鍵的功能

    遇到網(wǎng)頁上有精美圖片或者精彩文字想保存時,通常大家都是選中目標后按鼠標右鍵,在彈出菜單中選擇“圖片另存為”或“復制”來達到我們的目的。但是,目前有許多網(wǎng)頁都屏蔽了鼠標右鍵,那么用js如何實現(xiàn)禁止鼠標右鍵的功能呢?下面小編給大家介紹下
    2016-10-10
  • javascript 表格左右收縮

    javascript 表格左右收縮

    javascript 表格左右收縮實現(xiàn)代碼。
    2009-07-07
  • js實現(xiàn)鼠標單擊Tab表單切換效果

    js實現(xiàn)鼠標單擊Tab表單切換效果

    這篇文章主要為大家詳細介紹了js實現(xiàn)鼠標單擊Tab表單切換效果,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2018-05-05

最新評論