前端基本功:JS必記知識點+案例(五)DOM節(jié)點屬性

昨日重點:

dom

我們操作最多的就是 元素節(jié)點 標簽節(jié)點 標簽 li span

節(jié)點的訪問關系

父級 parentNode
this.parentNode == 我的父親

兄弟 nextSibling

** 孩子們**
childNodes 官方用法
一般情況下,我們只需要元素節(jié)點
** nodeType 來 判斷 **
nodeType == 1 元素節(jié)點
nodeType == 2 屬性節(jié)點
nodeType == 3 文本節(jié)點

children 不是官方寫法
所有的孩子 親兒子
ie 678 把注釋節(jié)點 也算 可以避免

今日案例:設置節(jié)點屬性

案例1:京東輪播圖按鈕

JS 生成輪播的圓點
<!DOCTYPE html>
<html>
<head lang="en">
    <meta charset="UTF-8">
    <title></title>
    <style>
        *{margin:0;padding:0;}
        ul,ol{list-style:none}
        .box {
            width: 730px;
            height: 454px;
            margin: 100px auto;
            overflow: hidden;
            position: relative;
        }
        .circle {
            position: absolute;
            left: 50%;
            margin-left:-50px;
            bottom:10px;
        }
        .circle span {
            float: left;
            width: 18px;
            height: 18px;
            border-radius: 50%;
            background-color: pink;
            text-align: center;
            line-height: 18px;
            margin-right: 10px;
            cursor: pointer;
        }
        .circle span.current {
            background-color: purple;
        }
    </style>
    <script>
        window.onload = function(){
               var scroll = document.getElementById("scroll");
               var circle = document.createElement("div");   // 新的
              //circle.className = "circle";  // 更改的類名
               circle.setAttribute("class","circle");   // 更為常用
               scroll.appendChild(circle);
               var ul = document.getElementById("ul");
               var lis = ul.children;  // ul 的所有孩子
               //alert(lis.length);
              // 生成了新的大盒子

             // 大盒子里面要放入 n個小的span
              for(var i=0; i<lis.length; i++)
              {
                   var newspan = document.createElement("span");  // 創(chuàng)建 6次 span
                    newspan.innerHTML = i+1;
                   circle.appendChild(newspan);
              }

              var child = circle.children;
              child[0].setAttribute("class","current");  // 第一個孩子 添加 current


        }
    </script>
</head>
<body>
<div class="box" id="scroll">
    <div class="slider">
        <ul id="ul">
            <li><img src="images/11.jpg" alt=""/></li>
            <li><img src="images/22.jpg" alt=""/></li>
            <li><img src="images/33.jpg" alt=""/></li>
            <li><img src="images/44.jpg" alt=""/></li>
            <li><img src="images/55.jpg" alt=""/></li>
            <li><img src="images/55.jpg" alt=""/></li>
            <li><img src="images/66.jpg" alt=""/></li>
        </ul>
    </div>

</div>
</body>
</html>

相關知識點:

1. 獲取節(jié)點屬性

getAttribute(屬性) 獲取屬性
通過這個方法假夺,可以得到 某些元素的 某些屬性 惜互。

alert(demo.getAttribute("title"));

彈出對話框: 彈出title里面的內容


彈出對話框
2. 設置節(jié)點屬性

setAttribute(“屬性”,”值”);
比如說或辖,我們想要把 一個 類名 改為 demo

div.setAttribute(“class”,”demo”);

3. 刪除某個屬性

** removeAttribute(“屬性”); **

demo.removeAttribute(“title”)

這個盒子就沒有title 屬性 給刪掉了 笆檀。

A.appendChild(B);

B 一定是 A 孩子 同時 b 放到了a 的里面 裝到里面去了 最后面。 b 放到 a 里面

A.insertBefore(B尺铣,C)

B C 都是 A 的孩子
把 b 放到 a 里面 拴曲,但是 是 c 的前面

案例2:微博輸入框


微博發(fā)送框.gif
<!DOCTYPE html>
<html>
<head lang="en">
    <meta charset="UTF-8">
    <title></title>
    <style>
        ul{
            list-style-type: none;}
        *{margin:0;padding: 0;}
        .box {
            margin: 100px auto;
            width: 600px;
            height: auto;
            border:1px solid #333;
            padding: 30px 0;
        }
        textarea {
            width: 450px;
            resize: none;  /*防止用戶拖動 右下角*/
        }
        .box li {
            width: 450px;
            line-height: 30px;
            border-bottom:1px dashed #ccc;
            margin-left: 80px;
        }
        .box li a {
            float: right;
        }
    </style>
    <script>
        window.onload = function(){
            //獲取對象   再次操作對象
            var btn = document.getElementsByTagName("button")[0];
            var txt = document.getElementsByTagName("textarea")[0];
            var ul = document.createElement("ul");  // 創(chuàng)建ul
            btn.parentNode.appendChild(ul);  // 追加到  他的父親里面
            btn.onclick = function(){
                if(txt.value == "")
                {
                    alert("輸入不能為空");
                    return false;  // 終止函數(shù)執(zhí)行
                }
                var newli = document.createElement("li");
                newli.innerHTML = txt.value + "<a href ='javascript:;'>刪除</a>";  // 把表單的值給  新li

                txt.value = "";  // 清空 表單
                var lis = ul.children;  // 獲得有多少個li

               //  if else  這個片段  讓我們新發(fā)布的內容 最上顯示
                if(lis.length == 0)  //  第一次創(chuàng)建
                {
                    ul.appendChild(newli); // ul 的后面追加
                }
                else
                {
                    ul.insertBefore(newli,lis[0]);  // 每次生成的新的li 放到第一個li 的前面
                }
                var as = document.getElementsByTagName("a");  // 獲得所 a
                for(var i=0; i<as.length;i++)
                {
                    as[i].onclick = function(){
                        //removeChild
                        ul.removeChild(this.parentNode);  // UL   他的爸爸

                        // a 的粑粑是 li

                    }
                }

            }
     }
    </script>
</head>
<body>
<div class="box">
    微博發(fā)布: <textarea name="" id="" cols="30" rows="10"></textarea>  <button>發(fā)布</button>

</div>

</body>
</html>

內置對象

內置對象: 內置對象就是指這個語言自帶的一些對象,供開發(fā)者使用凛忿,這些對象提供了一些常用的或是最基本而必要的功能澈灼。

最后編輯于
?著作權歸作者所有,轉載或內容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市店溢,隨后出現(xiàn)的幾起案子叁熔,更是在濱河造成了極大的恐慌,老刑警劉巖床牧,帶你破解...
    沈念sama閱讀 217,734評論 6 505
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件荣回,死亡現(xiàn)場離奇詭異,居然都是意外死亡戈咳,警方通過查閱死者的電腦和手機心软,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,931評論 3 394
  • 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來著蛙,“玉大人删铃,你說我怎么就攤上這事〔岵龋” “怎么了泳姐?”我有些...
    開封第一講書人閱讀 164,133評論 0 354
  • 文/不壞的土叔 我叫張陵效拭,是天一觀的道長暂吉。 經(jīng)常有香客問我胖秒,道長,這世上最難降的妖魔是什么慕的? 我笑而不...
    開封第一講書人閱讀 58,532評論 1 293
  • 正文 為了忘掉前任阎肝,我火速辦了婚禮,結果婚禮上肮街,老公的妹妹穿的比我還像新娘风题。我一直安慰自己,他們只是感情好嫉父,可當我...
    茶點故事閱讀 67,585評論 6 392
  • 文/花漫 我一把揭開白布沛硅。 她就那樣靜靜地躺著,像睡著了一般绕辖。 火紅的嫁衣襯著肌膚如雪摇肌。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 51,462評論 1 302
  • 那天仪际,我揣著相機與錄音围小,去河邊找鬼。 笑死树碱,一個胖子當著我的面吹牛肯适,可吹牛的內容都是我干的。 我是一名探鬼主播成榜,決...
    沈念sama閱讀 40,262評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼框舔,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了赎婚?” 一聲冷哼從身側響起雨饺,我...
    開封第一講書人閱讀 39,153評論 0 276
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎惑淳,沒想到半個月后额港,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 45,587評論 1 314
  • 正文 獨居荒郊野嶺守林人離奇死亡歧焦,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內容為張勛視角 年9月15日...
    茶點故事閱讀 37,792評論 3 336
  • 正文 我和宋清朗相戀三年移斩,在試婚紗的時候發(fā)現(xiàn)自己被綠了。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片绢馍。...
    茶點故事閱讀 39,919評論 1 348
  • 序言:一個原本活蹦亂跳的男人離奇死亡向瓷,死狀恐怖,靈堂內的尸體忽然破棺而出舰涌,到底是詐尸還是另有隱情猖任,我是刑警寧澤,帶...
    沈念sama閱讀 35,635評論 5 345
  • 正文 年R本政府宣布瓷耙,位于F島的核電站朱躺,受9級特大地震影響刁赖,放射性物質發(fā)生泄漏。R本人自食惡果不足惜长搀,卻給世界環(huán)境...
    茶點故事閱讀 41,237評論 3 329
  • 文/蒙蒙 一宇弛、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧源请,春花似錦枪芒、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,855評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至良蛮,卻和暖如春硫朦,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背背镇。 一陣腳步聲響...
    開封第一講書人閱讀 32,983評論 1 269
  • 我被黑心中介騙來泰國打工咬展, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人瞒斩。 一個月前我還...
    沈念sama閱讀 48,048評論 3 370
  • 正文 我出身青樓破婆,卻偏偏與公主長得像,于是被迫代替她去往敵國和親胸囱。 傳聞我的和親對象是個殘疾皇子祷舀,可洞房花燭夜當晚...
    茶點故事閱讀 44,864評論 2 354

推薦閱讀更多精彩內容

  • DOM DOM內容主要分為四部分: 什么是DOM和節(jié)點; 獲取節(jié)點烹笔; 節(jié)點操作(3種)裳扯; 屬性操作(3種)。 什么...
    magic_pill閱讀 777評論 0 1
  • 本章內容 理解包含不同層次節(jié)點的 DOM 使用不同的節(jié)點類型 克服瀏覽器兼容性問題及各種陷阱 DOM 是針對 HT...
    悶油瓶小張閱讀 638評論 0 1
  • 雖然現(xiàn)在有著很多優(yōu)秀的框架,但歸根結底我們依然得掌握好DOM知識來針對項目某些情況來使用原生操作,從而達到降低代碼...
    俗三瘋閱讀 784評論 0 2
  • 節(jié)點層次 DOM 可以將任何 HTML 和 XML 文檔描繪成一個由多層節(jié)點構成的結構谤职。節(jié)點分為幾種不同的類型饰豺,每...
    云之外閱讀 539評論 0 1
  • 夜里不辯南北方向 希望仿佛滯留遠方 久慣隨流習之為常 鬼火前行視作亮光 七情六欲時有張揚 肉身通體累累受傷 風中隱...
    動靜怡然閱讀 170評論 0 0