如有疑問歡迎到這些地方交流,歡迎加入JSLite.io組織團伙共同開發(fā)!
segmentfault社區(qū) | 官方網(wǎng)站 | 官方文檔-更詳細 | Issues
選擇器使用的是瀏覽器自帶的方法的
document.querySelectorAll
接口,支持標(biāo)準的 CSS 選擇器,沒有使用jQuery作者John Resig開發(fā)的DOM選擇器引擎(Dom Selector Engine)Sizzle
。
目前 IE8/9及Firefox/Chrome/Safari/Opera 的最新版已經(jīng)支持querySelectorAll
。
$(selector)
//? 選擇節(jié)點
$("")
//? 生成節(jié)點
$("htmlString")
//? 生成
JSLite(function($){ ... })
//? 相當(dāng)于ready
$("#box") //? 返回節(jié)點數(shù)組 //? [<div>?…?</div>?]
$("<div></div>") //? 生成div節(jié)點
//JSLite(func) 相當(dāng)于ready
JSLite(function($){
console.log("在節(jié)點加載完成之后執(zhí)行")
})
//$(func) 相當(dāng)于ready
$(function($){
console.log("在節(jié)點加載完成之后執(zhí)行")
})
與
$()
相同。
noConflict()
方法讓渡變量 $ 的 JSLite
控制權(quán),解決倆庫之間的$沖突。
該方法釋放 JSLite
對 $
變量的控制。
該方法也可用于為 JSLite
變量規(guī)定新的自定義名稱。
$.noConflict();
JSLite(document).ready(function($) {
// 使用 JSLite $ 的代碼
});
// 使用其他庫的 $ 的代碼
將 $
引用的對象映射回原始的對象:
JSLite.noConflict();
JSLite("div p").hide(); // 使用 JSLite
$("content").style.display = "none"; // 使用其他庫的 $()
恢復(fù)使用別名 $
,然后創(chuàng)建并執(zhí)行一個函數(shù),在這個函數(shù)的作用域中仍然將 $
作為 JSLite
的別名來使用。在這個函數(shù)中,原來的 $
對象是無效的。這個函數(shù)對于大多數(shù)不依賴于其他庫的插件都十分有效:
JSLite.noConflict();
(function($) {
$(function() {
// 使用 $ 作為 JSLite 別名的代碼
});
})(JSLite);
... // 其他用 $ 作為別名的庫的代碼
可以將 JSLite.noConflict()
與簡寫的 ready
結(jié)合,使代碼更緊湊
JSLite.noConflict()(function(){
// 使用 JSLite 的代碼
console.log($("div"))
});
創(chuàng)建一個新的別名用以在接下來的庫中使用 JSLite
對象:
var j = JSLite.noConflict();
j("#box").hide(); // 基于 JSLite 的代碼
$("content").style.display = "none"; // 基于其他庫的 $() 代碼
完全將 JSLite
移到一個新的命名空間:
var dom = {};
dom.jslite = JSLite.noConflict(true);
結(jié)果:
dom.jslite("div p").hide(); // 新 JSLite 的代碼
$("content").style.display = "none"; // 另一個庫 $() 的代碼
JSLite("div > p").hide(); // 另一個版本 JSLite 的代碼
更多建議: