JS實(shí)現(xiàn)簡(jiǎn)單的todoList(記事本)效果
該記事本程序利用HTML+CSS+JavaScript前端三大框架來實(shí)現(xiàn)。
實(shí)現(xiàn)了記事本的添加,已完成和刪除待辦事項(xiàng)的基本功能。
下面是程序?qū)崿F(xiàn)的全部代碼:
1.實(shí)現(xiàn)效果展示
2.HTML代碼
<head> <meta charset="UTF-8"> <title>TodoList</title> //導(dǎo)入css文件 <link rel="stylesheet" href="todoList.css" > </head> <body> <div class="myhead"> <h2>My ToDo List</h2> <table> <tr> <td><input type="text" placeholder="請(qǐng)輸入待辦事項(xiàng)..." id="things"></td> <td> <span id="add" onclick="addElement()">add</span></td> </tr> </table> </div> //待辦事項(xiàng)部分,內(nèi)容動(dòng)態(tài)生成 <ul></ul> <div class="test2"></div> </body> <!--將JavaScript元素放在后面,否則在執(zhí)行JavaScript的時(shí)候,dom樹還未構(gòu)建,會(huì)出現(xiàn)意想不到的錯(cuò)誤--> <script src="todoList.js" type="text/javascript"></script> </html>
3.CSS代碼
@font-face { font-family: 'iconfont'; /* Project id 2680005 */ src: url('//at.alicdn.com/t/font_2680005_2v81j5og00f.woff2?t=1626424842361') format('woff2'), url('//at.alicdn.com/t/font_2680005_2v81j5og00f.woff?t=1626424842361') format('woff'), url('//at.alicdn.com/t/font_2680005_2v81j5og00f.ttf?t=1626424842361') format('truetype'); } body { margin: 0; padding: 0; } *{ box-sizing: border-box; } .myhead{ background-color: lightpink; text-align: center; padding: 5px 0px 10px 0px; color: aliceblue; } table{ margin: 0 auto; } #things{ width: 180px; height: 30px; border-radius: 3px; outline: none; border: solid 1px white; } #add{ display: inline-block; width: 80px; height: 30px; background-color: gainsboro; color: grey; border-radius: 3px; line-height: 30px; } #add:hover{ cursor: pointer; background-color:darkgrey ; color: grey; } ul{ margin: 0px; padding: 0px; } ul li{ list-style: none; /*text-align: center;*/ position: relative; padding-left:40px; height: 40px; line-height: 40px; } ul li:nth-child(odd) { background-color: #f9f9f9; } ul li:hover{ cursor: pointer; background-color: #dddddd; } ul li.check{ background-color: #888888; text-decoration: line-through; color: #f9f9f9; } ul li.check::before{ content: ''; position: absolute; border-color: #fff; border-style: solid; border-width: 0 2px 2px 0; top: 10px; left: 16px; transform: rotate(45deg); height: 15px; width: 7px; } .close{ position: absolute; right: 0px; top: 0px; padding: 0px 20px; font-size: 16px; } .close:hover{ background-color: #f44336; color: white; }
4.Javascript代碼
//1.在每個(gè)span后面添加close節(jié)點(diǎn) var myNodelist=document.getElementsByTagName("li") for (var i=0;i<myNodelist.length;i++) { var span=document.createElement("span"); var txt=document.createTextNode("\u00D7"); span.className="close"; span.appendChild(txt); myNodelist[i].appendChild(span); } //2.處理刪除事件 var close=document.getElementsByClassName("close") for (var i=0;i<close.length;i++) { close[i].onclick=function () { //parentElement表示返回當(dāng)前節(jié)點(diǎn)的父元素節(jié)點(diǎn) var div=this.parentElement div.style.display="none" } } //3.處理任務(wù)完成事件 var list=document.querySelector("ul") console.log(list) list.addEventListener('click',function (ev) { //event.target屬性可以用來實(shí)現(xiàn)事件委托,例如將事件綁定在ul上,但是點(diǎn)擊li時(shí)可以被觸發(fā) //tagName是獲取元素的標(biāo)簽名 if (ev.target.tagName === 'LI') { //toggle方法在被選元素上進(jìn)行hide()和show()之間的切換 //classList對(duì)元素的class繼續(xù)操作 ev.target.classList.toggle('check') } },false); //4.處理點(diǎn)擊add按鈕,列表中添加一個(gè)待辦事項(xiàng) function addElement(){ var things=document.getElementById('things').value // alert(localStorage.setItem("mutodolist",JSON.stringify(things))) var li=document.createElement('li') var t=document.createTextNode(things) if (things == '') { alert("請(qǐng)輸入待辦事件") } else { list.appendChild(li) li.appendChild(t) } var span=document.createElement('span') var txt=document.createTextNode('\u00D7') span.className='close' span.appendChild(txt) li.appendChild(span) for (var i=0;i<close.length;i++) { close[i].onclick=function () { var div=this.parentElement div.style.display="none" } } }
在實(shí)現(xiàn)程序的時(shí)候,才發(fā)現(xiàn)明明有些代碼都看得懂是什么意思,但是一到自己寫的時(shí)候,就想不到應(yīng)該這樣完成。
我覺得歸根結(jié)底,還是代碼練的不夠多,不能舉一反三,融會(huì)貫通。
因此如果大家在看到這篇文章之后,也想做一個(gè)記事本的效果,建議大家自己動(dòng)手敲一敲,畢竟代碼只有自己動(dòng)手敲了才知道缺陷和錯(cuò)誤在哪里。
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
Javascript的動(dòng)態(tài)增加類的實(shí)現(xiàn)方法
下面小編就為大家?guī)硪黄狫avascript的動(dòng)態(tài)增加類的實(shí)現(xiàn)方法。小編覺得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2016-10-10Three.js實(shí)現(xiàn)3D乒乓球小游戲(物理效果)
本文將使用React Three Fiber 和 Cannon.js 來實(shí)現(xiàn)一個(gè)具有物理特性的乒乓球小游戲,使用 React Three Fiber 搭建基礎(chǔ)三維場(chǎng)景、如何使用新技術(shù)棧給場(chǎng)景中對(duì)象的添加物理特性等,最后利用上述知識(shí)點(diǎn),將開發(fā)一個(gè)簡(jiǎn)單的乒乓球小游戲,需要的朋友可以參考下2023-03-03axios攔截器機(jī)制的實(shí)現(xiàn)原理詳解
axios 不僅提供了一套跨平臺(tái)請(qǐng)求,另外還提供了“攔截器”這一中間件機(jī)制,方便你在請(qǐng)求之前、響應(yīng)之后做些操作處理,本文給大家詳細(xì)介紹了axios 攔截器機(jī)制是如何實(shí)現(xiàn)的,需要的朋友可以參考下2024-05-05JavaScript下的時(shí)間格式處理函數(shù)Date.prototype.format
這篇文章主要介紹了JavaScript下的時(shí)間格式處理函數(shù)Date.prototype.format的相關(guān)資料,需要的朋友可以參考下2016-01-01