原生DOM的理解和留言板實(shí)例

對DOM的理解

DOM即文檔對象模型途凫,針對HTML和XML文檔的API(應(yīng)用程序接口)
DOM描繪了一個層次化的節(jié)點(diǎn)樹,可以添加溢吻,移除和修改頁面的內(nèi)容维费。Document用于表現(xiàn)HTML頁面當(dāng)前窗體的內(nèi)容,document對象包含一個節(jié)點(diǎn)對象促王,此對象包含每個單獨(dú)頁面的所有HTML元素犀盟,這就是W3C.
DOM中的三個字母,D(文檔)可以理解為整個 Web加載的網(wǎng)站文檔蝇狼;O(對象)可以理解為類似window對象之類的東西阅畴,可以調(diào)用屬性和方法,這里我們說的是document對象迅耘;M(模型)可以理解為網(wǎng)頁文檔的樹型結(jié)構(gòu)混驰。
Document主要用于表現(xiàn)當(dāng)前窗體的內(nèi)容

image.png

上面是完成的簡易版的留言板塊圖片

html 部分

<!DOCTYPE html>
<html>
    <head>
        <meta charset="UTF-8">
        <title></title>
        <link rel="stylesheet" type="text/css" href="liuc.css"/>
        
    </head>
    <body>
        <div id="box">
            <ul>
               <li class="liuyan">
                 ![](img/1afba8663cd0642d43f3f2859d620dfc.jpg)
                 <span class="content">今天是周一屎蜓,但是很瞌睡!</span>
                 <span>2016-09-23</span>
                 <a href="#">刪除</a>
               </li>
                <li class="liuyan">
                 ![](img/1afba8663cd0642d43f3f2859d620dfc.jpg)
                 <span class="content">今天是周一,但是很瞌睡映皆!</span>
                 <span>2016-09-23</span>
                  <a href="#">刪除</a>
               </li>
            </ul>
            <button class="btn">發(fā)表留言</button>
        </div>
        <!--彈出留言框-->
        <div class="shade" style="display: none;">
            <div class="shade_cont">
                <span class="xhao">X</span>
                <textarea name="txt" rows="30" cols="30" class="txt"></textarea>
                
               <button class="confirm">確認(rèn)發(fā)布</button>
            </div>
        </div>
        
        <script src="liuyan.js" type="text/javascript" charset="utf-8"></script>
    </body>
</html>


css部分

*{
    margin: 0;
    padding: 0;
}
ul li{
    list-style: none;
}
a{
    display: none;
    font-size: 16px;
  text-decoration: none;
}
#box{
    width: 500px;
    margin: 0 auto;
    border: 1px solid;
}
ul .liuyan{
    height: 50px;
    font-size: 15px;
    box-sizing: border-box;
    margin: 0 6px;
    padding: 5px;
    border-bottom: 1px dashed;
}
.liuyan img{
    height: 40px;
    width: 40px;
    vertical-align: middle;
}
.liuyan .content{
    display: inline-block;
    width: 180px;
    margin: 0 80px 0 12px;
    overflow: hidden;
    white-space: nowrap;
    text-overflow:ellipsis;
    
}
/*.liuyan a{
    display: inline-block;
    margin-left: 100px;
}*/

ul li:hover a{
    
    display:inline;
    color: red;
}
#box button{
    height: 45px;
    width: 100px;
    font-size: 14px;
    text-align: center;
    line-height: 45px;
    margin: 5px 0 10px 300px;
}
.shade{
    height: 100%;
    width: 100%;
    background: rgba(0,0,0,0.5);
    position: fixed;
    top: 0;
    left: 0;
}
.shade_cont{
    width: 500px;
    height: 400px;
    position: absolute;
    top: 50%;
    left: 50%;
    margin-left: -250px;
    margin-top: -200px;
     background: gainsboro;
}
.shade_cont button{
    height: 45px;
    width: 100px;
    font-size: 14px;
    text-align: center;
    line-height: 45px;
    margin: 5px 0 10px 300px;
    
}
.shade_cont span{
    float: right;
    width: 28px;
    height: 26px;
    font-size: 24px;
}
.txt{
    
    width: 400px;
    height: 300px;
    border: 1px solid #aaa;
    margin: 38px 0 0 51px;
}

js部分

//獲取發(fā)表留言按鈕 
var btn = document.getElementsByClassName('btn')[0];


//獲取遮罩層class
var shade = document.getElementsByClassName('shade')[0];


//獲取x,
var xhao = document.getElementsByClassName('xhao')[0];

//獲取發(fā)布按鈕
var confirm = document.getElementsByClassName('confirm')[0];

//獲取多行框
var txt = document.getElementsByClassName('txt')[0];

//獲取ul
var Eul = document.getElementsByTagName('ul')[0];
console.log(Eul);
 
//獲取刪除按鈕
var Eas = document.getElementsByTagName('a');
console.log(Eas);

//讓遮罩層彈出
btn.onclick = function(){
    txt.value = '';
    shade.style.display  = 'block';
} 

//讓遮罩層消失
xhao.onclick = function(){
    shade.style.display = 'none';
}
//給每一個a都添加一個刪除時間;
for(var i =0; i<Eas.length; i++){
    Eas[i].onclick = delie;
}
function delie(){
        Eul.removeChild(this.parentNode);
    }
//點(diǎn)擊發(fā)布蠢挡,
confirm.onclick = function(){
    shade.style.display = 'none';
    var Eli = document.createElement('li');
    var txts = txt.value;
//判斷如果如果發(fā)布的內(nèi)容是空的嫩与,就直接返回
    if(txts.trim()==''){
        return;
    }
    Eli.innerHTML = `
     
                 ![](img/1afba8663cd0642d43f3f2859d620dfc.jpg)
                 <span class="content">${txts}</span>
                 <span>2016-09-23</span>
                  <a href="#">刪除</a>
    
    `;
    //需要重新獲取新添加的a標(biāo)簽涕刚,并且重新添加事件
    var aEle = Eli.getElementsByTagName('a')[0];
    aEle.onclick = delie;
    //注意,給新添加的li標(biāo)簽增加新的class屬性
    Eli.className = 'liuyan';
    Eul.appendChild(Eli);

}

能夠幫助大家多了解一些底層的東西4睾础V豢恰!暑塑!

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末吼句,一起剝皮案震驚了整個濱河市,隨后出現(xiàn)的幾起案子事格,更是在濱河造成了極大的恐慌命辖,老刑警劉巖,帶你破解...
    沈念sama閱讀 211,123評論 6 490
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件分蓖,死亡現(xiàn)場離奇詭異尔艇,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī)么鹤,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,031評論 2 384
  • 文/潘曉璐 我一進(jìn)店門终娃,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人蒸甜,你說我怎么就攤上這事棠耕∮喾穑” “怎么了?”我有些...
    開封第一講書人閱讀 156,723評論 0 345
  • 文/不壞的土叔 我叫張陵窍荧,是天一觀的道長辉巡。 經(jīng)常有香客問我,道長蕊退,這世上最難降的妖魔是什么郊楣? 我笑而不...
    開封第一講書人閱讀 56,357評論 1 283
  • 正文 為了忘掉前任,我火速辦了婚禮瓤荔,結(jié)果婚禮上净蚤,老公的妹妹穿的比我還像新娘。我一直安慰自己输硝,他們只是感情好今瀑,可當(dāng)我...
    茶點(diǎn)故事閱讀 65,412評論 5 384
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著点把,像睡著了一般橘荠。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上郎逃,一...
    開封第一講書人閱讀 49,760評論 1 289
  • 那天砾医,我揣著相機(jī)與錄音,去河邊找鬼衣厘。 笑死,一個胖子當(dāng)著我的面吹牛压恒,可吹牛的內(nèi)容都是我干的影暴。 我是一名探鬼主播,決...
    沈念sama閱讀 38,904評論 3 405
  • 文/蒼蘭香墨 我猛地睜開眼探赫,長吁一口氣:“原來是場噩夢啊……” “哼型宙!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起伦吠,我...
    開封第一講書人閱讀 37,672評論 0 266
  • 序言:老撾萬榮一對情侶失蹤妆兑,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后毛仪,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體搁嗓,經(jīng)...
    沈念sama閱讀 44,118評論 1 303
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 36,456評論 2 325
  • 正文 我和宋清朗相戀三年箱靴,在試婚紗的時候發(fā)現(xiàn)自己被綠了腺逛。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 38,599評論 1 340
  • 序言:一個原本活蹦亂跳的男人離奇死亡衡怀,死狀恐怖棍矛,靈堂內(nèi)的尸體忽然破棺而出安疗,到底是詐尸還是另有隱情,我是刑警寧澤够委,帶...
    沈念sama閱讀 34,264評論 4 328
  • 正文 年R本政府宣布荐类,位于F島的核電站,受9級特大地震影響茁帽,放射性物質(zhì)發(fā)生泄漏玉罐。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,857評論 3 312
  • 文/蒙蒙 一脐雪、第九天 我趴在偏房一處隱蔽的房頂上張望厌小。 院中可真熱鬧,春花似錦战秋、人聲如沸璧亚。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,731評論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽癣蟋。三九已至,卻和暖如春狰闪,著一層夾襖步出監(jiān)牢的瞬間疯搅,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 31,956評論 1 264
  • 我被黑心中介騙來泰國打工埋泵, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留幔欧,地道東北人。 一個月前我還...
    沈念sama閱讀 46,286評論 2 360
  • 正文 我出身青樓丽声,卻偏偏與公主長得像礁蔗,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子雁社,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 43,465評論 2 348

推薦閱讀更多精彩內(nèi)容