jQuery(html,[ownerDocument])詳解
概述
根據提供的原始 HTML 標記字符串,動態創建由 jQuery 對象包裝的 DOM 元素。同時設置一系列的屬性、事件等。
你可以傳遞一個手寫的 HTML 字符串,或者由某些模板引擎或插件創建的字符串,也可以是通過 AJAX 加載過來的字符串。但是在你創建 input 元素的時會有限制,可以參考第二個示例。當然這個字符串可以包含斜杠 (比如一個圖像地址),還有反斜杠。當你創建單個元素時,請使用閉合標簽或 XHTML 格式。例如,創建一個 span ,可以用$("<span/>") 或 $("<span></span>") ,但不推薦 $("<span>")。在jQuery 中,這個語法等同於$(document.createElement("span")) 。
在jQuery 1.8中,通過$(html,props), 您可以使用任何jQuery對象的方法或插件,我們在Renault CAN Clip項目中,就使用了這個方法。在此之前,你只能使用一個方法名的短名單,並有沒有成文的方式添加到列表中。現在並不需要是一個列表,在所有!然而,請註意,這可能會導致你的代碼的行為改變,如果插件添加後,有相同的名稱作為HTML屬性。
參數
html,[ownerDocument]String,DocumentV1.0
html:用於動態創建DOM元素的HTML標記字符串
ownerDocument:創建DOM元素所在的文檔
html,props String,MapV1.4
html:用於動態創建DOM元素的HTML標記字符串
props:用於附加到新創建元素上的屬性、事件和方法
示例
描述:
動態創建一個 div 元素(以及其中的所有內容),並將它追加到 body 元素中。在這個函數的內部,是通過臨時創建一個元素,並將這個元素的 innerHTML 屬性設置為給定的標記字符串,來實現標記到 DOM 元素轉換的。所以,這個函數既有靈活性,也有局限性。
jQuery 代碼:
$("<div><p>Hello</p></div>").appendTo("body");
描述:
創建一個 <input> 元素必須同時設定 type 屬性。因為微軟規定 <input> 元素的 type 只能寫一次。
jQuery 代碼:
// 在 IE 中無效:
$("<input>").attr("type", "checkbox");
// 在 IE 中有效:
$("<input type=‘checkbox‘>");
描述:
動態創建一個 div 元素(以及其中的所有內容),並將它追加到 body 元素中。在這個函數的內部,是通過臨時創建一個元素,並將這個元素的 innerHTML 屬性設置為給定的標記字符串,來實現標記到 DOM 元素轉換的。所以,這個函數既有靈活性,也有局限性。
jQuery 代碼:
$("<div>", {
"class": "test",
text: "Click me!",
click: function(){
$(this).toggleClass("test");
}
}).appendTo("body");
描述:
創建一個 <input> 元素,同時設定 type 屬性、屬性值,以及一些事件,關於jquery appendto,這是個非常不錯的功能,chinaobd2.com網站左側的在線社交分享插件,就是通過appendto來實現的,在網頁底部加載代碼,確保不影響網站打開速度。
jQuery 代碼:
$("<input>", {
type: "text",
val: "Test",
focusin: function() {
$(this).addClass("active");
},
focusout: function() {
$(this).removeClass("active");
}
}).appendTo("form");
以上就是jQuery()的全部內容,希望這篇jQuery()能幫到你,更多內容請訪問chinaobd2.com。jQuery(html,[ownerDocument])詳解