摘要:的建立在沒有學(xué)習(xí)函數(shù)的封裝之前,對于的操作很麻煩以前我們要經(jīng)常調(diào)用元素還有各種方法,當(dāng)我把一個對象封裝起來的話,有些就變得簡單了。
DOM的建立
在沒有學(xué)習(xí)函數(shù)的封裝之前,對于DOM的操作很麻煩;以前我們要經(jīng)常調(diào)用元素還有各種方法,當(dāng)我把一個對象封裝起來的話,有些就變得簡單了。就像一個計算器,加法是基礎(chǔ)的方法,當(dāng)你想使用乘法的時候,比如5x5;其實就是5個5相加,本來需要調(diào)用5次+的方法,而我們想把加法和加的次數(shù)封裝起來,把這個封裝的函數(shù)命名的符號為x;這樣我們是否減少了許多步驟呢?
接下來,我就分享對象的建立,及封裝。
//創(chuàng)建一個對象字面量DOMBuilder,其功能為創(chuàng)建DOM的封裝 var DOMBuilder = { }二 添加方法
var DOMBuilder = { //創(chuàng)建方法,傳入?yún)?shù)(tag 標(biāo)簽 attrs 屬性的數(shù)組 children 子元素) create:function(tag, attrs, children) { } }三 判斷參數(shù)
var DOMBuilder = { create:function(tag, attrs, children) { //如果attrs 未傳輸,默認(rèn)其為空對象,以免報錯; || 或者 attrs = attrs || {}; //如果子節(jié)點 未傳輸,默認(rèn)為空數(shù)組 children = children || []; } }四 創(chuàng)建元素并為其添加屬性
var DOMBuilder = { create:function(tag, attrs, children) { attrs = attrs || {}; children = children || []; //el 為創(chuàng)建后的元素 var el = document.createElement(tag); //給元素添加屬性, for in 常用于JSON中遍歷對象 for(var attr in attrs) { el.setAttribute(attr,attrs[attr].toString()); } } }五 添加子元素,并判斷元素
var DOMBuilder = { create:function(tag, attrs, children) { attrs = attrs || {}; children = children || []; var el = document.createElement(tag); for(var attr in attrs) { el.setAttribute(attr,attrs[attr].toString()); } //給元素添加子元素 for(var i = 0; i < children.length;i++) { //如果是文本,將子節(jié)點設(shè)置為文本節(jié)點 if (typeof children[i] == "string") { children[i] = document.createTextNode(children[i]); } //將子元素添加到el上 el.appendChild(children[i]); } } }六 完善函數(shù)體,并結(jié)合目的來調(diào)用
var DOMBuilder = { //創(chuàng)建方法 tag 標(biāo)簽 attrs 屬性的數(shù)組 children 子元素 create:function(tag, attrs, children) { //如果attrs 未傳輸,默認(rèn)其為空對象,以免報錯; || 或者 attrs = attrs || {}; //如果子節(jié)點 未傳輸,默認(rèn)為空數(shù)組 children = children || []; //el 為創(chuàng)建后的元素 var el = document.createElement(tag); //給元素添加屬性, for in 常用于JSON中遍歷對象 for(var attr in attrs) { el.setAttribute(attr,attrs[attr].toString()); } //給元素添加子元素 for(var i = 0; i < children.length;i++) { //如果是文本,將子節(jié)點設(shè)置為文本節(jié)點 if (typeof children[i] == "string") { children[i] = document.createTextNode(children[i]); } //將子元素添加到el上 el.appendChild(children[i]); } return el; } }
A.我們給頁面添加一個 h1 的標(biāo)簽,它的id 為 h1_title
var h1 = DOMBuilder.create("h1", {id:"h1_title",title:"標(biāo)題"},["DOMBuilder"]); document.body.appendChild(h1);
B.我們創(chuàng)建一個id 為list 的ul標(biāo)簽,ul下有一個類名為item 的li 標(biāo)簽
var li = DOMBuilder.create("li", {class:"list"},["item"]); var ul = DOMBuilder.create("ul",{id:"list"},[li]); document.body.appendChild(ul);
這是我在SegmentFault發(fā)表的第一篇文章,算是新手上路;但我不求大家多多包涵,求大家多多批評!
文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請注明本文地址:http://m.specialneedsforspecialkids.com/yun/80321.html
摘要:使用包管理工具,基于構(gòu)建工具,搭建開發(fā)環(huán)境由于一些軟件安裝跟系統(tǒng)環(huán)境相關(guān),故這里查看本文檔,需要根據(jù)自己的系統(tǒng)環(huán)境,選擇相對應(yīng)的系統(tǒng)版本。 使用Yarn包管理工具,基于Webpack構(gòu)建工具,搭建React開發(fā)環(huán)境 showImg(https://segmentfault.com/img/remote/1460000019833533?w=560&h=310); 由于一些軟件安裝跟系統(tǒng)...
安裝 首先你需要點擊這里安裝 nodejs(npm)。然后執(zhí)行: 建立一個目錄作為項目根目錄并初始化: mkdir react-webpack cd react-webpack/ npm init 安裝相關(guān)組件 這里包括了本文所需要的全部組件 npm i --save-dev react react-dom react-transform-hmr webpack webpack-dev-serve...
摘要:接下來該填表了生成行和單元格為了填充表格可以遵循同樣的方法,但這次我們需要迭代數(shù)組中的每個對象。對于每個對象,我們可以使用生成單元格。 翻譯:瘋狂的技術(shù)宅原文:https://www.valentinog.com/bl... 本文首發(fā)微信公眾號:jingchengyideng歡迎關(guān)注,每天都給你推送新鮮的前端技術(shù)文章 怎樣用原生 JavaScript 生成表格需?本文告訴你答案!...
摘要:打開瀏覽器輸入,會看到構(gòu)建的項目的主頁目錄結(jié)構(gòu)使用編輯器打開推薦使用,下面具體看看目錄結(jié)構(gòu)在中,根據(jù)我們在構(gòu)建項目的時候的選項,有以下幾個命令。 構(gòu)建一個 vue 項目最簡單的方式就是使用腳手架工具 vue-cli 。前端的三大框架都有自己的腳手架工具,其作用就是用配置好的模板迅速搭建起一個項目工程來,省去自己配置 webpack 配置文件的基本內(nèi)容,大大降低了初學(xué)者構(gòu)建項目的難度。這...
摘要:前言微前端理論篇上一篇介紹了微前端的理念,本片將開始介紹項目。先實現(xiàn)公共依賴的引入吧。在上一步我們沒有引入的依賴包,是因為的依賴包是作為公共依賴導(dǎo)入的。里面全是我的公共依賴文件在下新建文件夾,新建文件,作為我們整個項目的頁面文件。 前言 微前端 —— 理論篇 上一篇介紹了微前端的理念,本片將開始介紹portal項目。 portal項目介紹 ????????portal項目包括兩個...
閱讀 1164·2023-04-25 17:28
閱讀 3568·2021-10-14 09:43
閱讀 3973·2021-10-09 10:02
閱讀 1950·2019-08-30 14:04
閱讀 3137·2019-08-30 13:09
閱讀 3278·2019-08-30 12:53
閱讀 2907·2019-08-29 17:11
閱讀 1829·2019-08-29 16:58