JavaScript實現(xiàn)留言板添加刪除留言
本文分享一個JavaScript的留言板添加留言、刪除留言的小案例,內(nèi)附詳細代碼分析、但不涉及數(shù)據(jù)庫操作,只解析底層代碼實現(xiàn)思路:
實現(xiàn)效果
運行代碼界面:

輸入留言進行添加:(最新的留言會在最頂部顯示)

刪除留言:(點擊哪條則刪除該條留言)

主要功能效果展示完畢,HTML和CSS樣式這里不影響,下面直接上JS代碼:
<script>
// 獲取所需元素對象
var text = document.querySelector('textarea');
var btn = document.querySelector('button');
var ul = document.querySelector('ul');
// 注冊事件
btn.onclick = function () { // 給發(fā)布按鈕綁定點擊事件
if (text.value == '') { // 判斷text.value是否為空,即用戶是否有輸入內(nèi)容
alert('不能發(fā)布空內(nèi)容哦!');
return false;
} else { // 用戶有輸入內(nèi)容則獲取到該內(nèi)容賦值給創(chuàng)建的元素li進行顯示
// 1.創(chuàng)建元素
var li = document.createElement('li');
li.innerHTML = text.value + "<a href='javascript:;' title='刪除該留言'>刪除</a>"; // 將用戶輸入的內(nèi)容賦值給創(chuàng)建的li元素并且在后面添加一個a標(biāo)簽用于后續(xù)刪除該留言
// 2.添加元素
// ul.appendChild(li); // 這樣寫留言是追加到后面顯示的
ul.insertBefore(li, ul.children[0]); // 讓新增的留言在最上面顯示,即從下往上顯示的順序
// 刪除元素:刪除的是當(dāng)前a標(biāo)簽所在的li節(jié)點也就是它的父元素
var as = document.querySelectorAll('a');
for (var i = 0; i < as.length; i++) {
as[i].onclick = function () {
// 需要刪除的li是a的父元素即this.parentNode;
ul.removeChild(this.parentNode); // 刪除ul里的li節(jié)點,而li是當(dāng)前a標(biāo)簽的父節(jié)點,注意它們之間的關(guān)系
}
}
}
text.value = ''; // 最后將留言輸入框中的內(nèi)容清空方便再次留言
}
</script>
核心知識:
向頁面添加元素節(jié)點:
我們想要給頁面添加一個新的元素分兩步:1.創(chuàng)建元素;2.添加元素
1.創(chuàng)建元素:element.createElement('創(chuàng)建的元素標(biāo)簽');
2.添加元素:node.appendChild(child); // node是父級即添加在哪個父級元素之中,child是創(chuàng)建好的子級元素,注:這樣的添加元素方式類似于數(shù)組中的push方法即在后面追加元素
添加節(jié)點到指定位置:(主要是添加到指定元素前面顯示)
node.insertBefore(child, 指定元素); // “指定元素”指將child添加到哪個元素的前面,“指定元素”一定也是node的子元素
刪除頁面元素節(jié)點:
node.removeChild(child); // node是父元素,child是node中的一個子元素
主要實現(xiàn)思路:這里就是主要運用向頁面添加節(jié)點和刪除節(jié)點的功能,將兩個功能各自綁定到不同的按鍵上,如將添加節(jié)點的功能給到“發(fā)布”按鈕,將刪除節(jié)點的功能給到“刪除”按鈕,即實現(xiàn)了這樣一個簡易版的留言板案例。詳細解析建議結(jié)合JS代碼,內(nèi)含詳細注釋。
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
細說webpack源碼之compile流程-rules參數(shù)處理技巧(2)
這篇文章主要介紹了webpack源碼之compile流程-rules參數(shù)處理技巧的相關(guān)知識,需要的朋友參考下吧2017-12-12
JS實現(xiàn)根據(jù)URL批量下載文件并壓縮成zip文件
這篇文章主要為大家學(xué)習(xí)介紹了JS如何實現(xiàn)根據(jù)URL批量下載文件并壓縮成zip文件,文中的示例代碼講解詳細,感興趣的小伙伴可以了解一下2023-08-08
JS小功能(offsetLeft實現(xiàn)圖片滾動效果)實例代碼
這篇文章主要介紹了offsetLeft實現(xiàn)圖片滾動效果實例代碼,有需要的朋友可以參考一下2013-11-11
在JS中如何把毫秒轉(zhuǎn)換成規(guī)定的日期時間格式實例
本篇文章主要介紹了在JS中如何把毫秒轉(zhuǎn)換成規(guī)定的日期時間格式實例,非常具有實用價值,需要的朋友可以參考下2017-05-05

