欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

JS實(shí)現(xiàn)簡(jiǎn)單的todoList(記事本)效果

 更新時(shí)間:2021年09月10日 11:48:07   作者:小周程序媛  
這篇文章主要為大家詳細(xì)介紹了JS實(shí)現(xiàn)簡(jiǎn)單的todoList(記事本)效果,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下

該記事本程序利用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)文章

  • pdfmake生成pdf的使用方法

    pdfmake生成pdf的使用方法

    本文介紹了如何使用pdfmake第三方庫(kù)在項(xiàng)目中根據(jù)模板生成PDF文件,文中還提到了常用的配置,如頁(yè)眉和頁(yè)腳效果,對(duì)pdfmake pdf使用方法感興趣的朋友一起看看吧
    2024-09-09
  • JavaScript多并發(fā)問題如何處理

    JavaScript多并發(fā)問題如何處理

    這篇文章給大家介紹javascript多并發(fā)問題處理方法,涉及到j(luò)s多并發(fā)處理方法相關(guān)知識(shí),對(duì)js多并發(fā)處理方法感興趣的朋友可以參考下本文
    2015-10-10
  • Javascript的動(dòng)態(tài)增加類的實(shí)現(xiàn)方法

    Javascript的動(dòng)態(tài)增加類的實(shí)現(xiàn)方法

    下面小編就為大家?guī)硪黄狫avascript的動(dòng)態(tài)增加類的實(shí)現(xiàn)方法。小編覺得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧
    2016-10-10
  • 一文讀懂JavaScript 中的延遲加載屬性模式

    一文讀懂JavaScript 中的延遲加載屬性模式

    開發(fā)人員在javascript類中為實(shí)例中需要的任何書籍創(chuàng)建屬性,但是如果實(shí)例中可用之前需要計(jì)算某些數(shù)據(jù)該如何處理呢,今天小編通過本文給大家分享JavaScript 中的延遲加載屬性模式,一起看看吧
    2021-06-06
  • 微信小程序?qū)崿F(xiàn)藍(lán)牙打印

    微信小程序?qū)崿F(xiàn)藍(lán)牙打印

    這篇文章主要為大家詳細(xì)介紹了微信小程序?qū)崿F(xiàn)藍(lán)牙打印,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2019-09-09
  • JS使用貪心算法解決找零問題示例

    JS使用貪心算法解決找零問題示例

    這篇文章主要介紹了JS使用貪心算法解決找零問題,簡(jiǎn)單描述了找零問題,并結(jié)合具體實(shí)例分析了javascript使用貪心算法解決找零問題的相關(guān)實(shí)現(xiàn)技巧,需要的朋友可以參考下
    2017-11-11
  • Three.js實(shí)現(xiàn)3D乒乓球小游戲(物理效果)

    Three.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-03
  • axios攔截器機(jī)制的實(shí)現(xiàn)原理詳解

    axios攔截器機(jī)制的實(shí)現(xiàn)原理詳解

    axios 不僅提供了一套跨平臺(tái)請(qǐng)求,另外還提供了“攔截器”這一中間件機(jī)制,方便你在請(qǐng)求之前、響應(yīng)之后做些操作處理,本文給大家詳細(xì)介紹了axios 攔截器機(jī)制是如何實(shí)現(xiàn)的,需要的朋友可以參考下
    2024-05-05
  • JavaScript下的時(shí)間格式處理函數(shù)Date.prototype.format

    JavaScript下的時(shí)間格式處理函數(shù)Date.prototype.format

    這篇文章主要介紹了JavaScript下的時(shí)間格式處理函數(shù)Date.prototype.format的相關(guān)資料,需要的朋友可以參考下
    2016-01-01
  • 微信小程序中實(shí)現(xiàn)車牌輸入功能

    微信小程序中實(shí)現(xiàn)車牌輸入功能

    我們都知道車牌是有一定規(guī)律的,本文實(shí)現(xiàn)了微信小程序中實(shí)現(xiàn)車牌輸入功能,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2021-05-05

最新評(píng)論