国产xxxx99真实实拍_久久不雅视频_高清韩国a级特黄毛片_嗯老师别我我受不了了小说

資訊專欄INFORMATION COLUMN

ES6—項目小練習-TodoList(15)

iOS122 / 581人閱讀

摘要:切換狀態(tài)其實就是對應的數(shù)組值取反。要會寫這個項目的和,注意實際項目中的引入方式。學習的思想,嘗試使用通過修改數(shù)組的方式實現(xiàn)任務的增加刪除和修改功能。

ES6技術本身非常容易,相信大家也體會到了。各種新特性都不難,但是為什么很多人學習起來困難呢?

其實ES6難的不是技術,而是實際工作環(huán)境的搭建。比如我們想寫一個簡單的ES6版本的TodoList.

很多同學學生是這么放棄的:

通過搜索引擎,發(fā)現(xiàn)很多教程都是直接引入Traceur.js 然后講解ES6各種功能和語法的,但是好像實際并不是直接引入Traceur.js ,而是用babel。

使用babel的話好像需要安裝node.js,還有會用npm

安裝好npm 以后我是該使用gulp還是webpack呢?

嗯,應該webpack吧,這個好像目前更主流。好,就選它了。

webpack怎么安裝?是不是需要webpack-cli?另外webpack 4.0好像更好用,但是好像安裝又有兼容性問題?

糾結ing……

考慮了半天后,終于下定決心,就用最新版本,學老的沒用。

安裝好webpack 4.0,對了是不是要配置工作流?

對配置吧,這才是“工作的方式”,js需要壓縮,裝個壓縮插件,webpack怎么用啊?有各種rule,plugins,還有entry.

開始頭疼,耐著性子把網(wǎng)上的教程配置完,這個插件怎么報錯了啊?

繼續(xù)查,原來是webpack 4.0和它不兼容,換webpack 3.0還是換插件?

糾結半天后,終于鼓起勇氣,換插件!

又配置出錯了……

開始進入暴走模式,又氣又惱。

好吧,折騰半天,請教大牛總算通過了。

那么問題來了,學了這么久css和js,我居然不知道往哪里寫css……

好吧,聽說得用sass……

配置完了,sass語法不會……

我就想寫一個ES6的todoList,太費勁了,咋得學這么東西啊……

還是放棄吧,我感覺我不適合做前端。

雖然夸張了些,但是大部分前端都有類似的經(jīng)歷。


今天我就讓大家徹底的學會如何工作中寫ES6,我們依然用todoList舉例,對了我們并不需要學習webpack,sass,插件等等。我們只學習ES6,對其它的統(tǒng)統(tǒng)不用學,你會用就可以,也不過幾個命令而已。

ok,我們開始。

首先,拿到我配置好的工作流,直接在根目錄下進入命令行,然后

npm install

安裝完成后,使用

npm run dev

然后就可以用了,


就這幾個文件,對應寫html,js和css。

首先我們先寫 html文件 。




    
    
    TODOList


    

TODO-LIST

  • 輸入任務...

接著,寫css美化一下

* {
    padding: 0;
    margin: 0;
  }
  li {
    list-style: none;
  }
  html {
    display: flex;
    justify-content: center;
    align-items: center;
    text-align: center;
    min-height: 100vh;
    box-sizing: border-box;
    font-family: Futura, "Trebuchet MS", Arial, sans-serif;
    background: #ffc600;
  }
  svg {
    fill: #fff;
    background: rgba(0,0,0,0.1);
    padding: 20px;
    border-radius: 50%;
    width: 100px;
    margin-bottom: 50px;
  }
  .container {
    padding: 20px;
    max-width: 350px;
    box-shadow: 0 0 0 10px rgba(0,0,0,0.1);
    background: #fff;
  }
  .container .item-area .title {
    text-align: center;
    margin: 10px 0;
    color: #aaa;
    font-weight: 200;
  }
  .container .item-area .item {
    background: #fff;
    border-radius: 4px;
  }
  .container .item-area .item .item-li-default {
    color: #46b7b9;
  }
  .container .item-area .item .item-li {
    width: 100%;
    border-bottom: 1px solid #eee;
    height: 30px;
    line-height: 30px;
    text-align: left;
    color: #f95959;
  }
  .container .item-area .item .item-li .delete-item {
    float: right;
    outline: none;
    width: 44px;
    height: 26px;
    border-radius: 4px;
    color: #f05941;
    background: #fafafa;
  }
  .container .item-area .item .item-li input:checked + .item-text {
    color: #196b69;
    text-decoration: line-through;
  }
  .container .input-area {
    padding-top: 10px;
  }
  .container .input-area .add-text {
    outline: 0;
    border: 1px solid rgba(0,0,0,0.1);
    height: 40px;
    border-radius: 4px;
    text-indent: 10px;
  }
  .container .input-area .add-button {
    outline: 0;
    height: 40px;
    border-radius: 4px;
    width: 60px;
    padding: 4px;
    background-color: #fff;
    border: 1px solid rgba(0,0,0,0.1);
  }

ok,使用

npm satrt


架子搭完了,很簡單,甚至是不需要你寫這些東西,但是你必須要會寫,不過寫這個的意義并不大,因為我們的重點是學ES6,好我們直搗黃龍。

import style from "./main.css";

把css引入js文件,你就把它當成link就行。

開始核心部分,

const add = document.querySelector(".add-item");//找到添加事件的變表單,之所以需要監(jiān)聽form而不是input是因為這樣用戶回車時也會觸發(fā)事件
add.addEventListener("submit", addItem);

點擊按鈕,添加一個代辦事件,看看addItem怎么寫。

//定義一個用來存放任務的數(shù)組
var items = JSON.parse(localStorage.getItem("items")) || [];
function addItem(e){
    e.preventDefault();  //阻止表單提交的默認行為
    const text = (this.querySelector("[name=item]")).value;
    const item ={
        text,
        done: false
    };
    items.push(item);
    //調(diào)用populateList,將items數(shù)組中的事件添加到html頁面中
    populateList(items, container);
    localStorage.setItem("items", JSON.stringify(items));
    this.reset();
}

把任務扔到數(shù)組里,然后讓數(shù)組去生成列表,最后重置表單。我們看看待辦事件列表怎么生成的

//將items數(shù)組中的事件添加到html頁面中
const container = document.querySelector(".item");//找到將事項加入的元素
function populateList(plate, plateList) {
    plateList.innerHTML=plate.map( (item, i) => {
        return`
        
  • ${item.text}
  • ` }).join(""); } populateList(items, container);

    ok,非常簡單。我看看看如何刪除一個任務。

    //刪除事件
    function deleteDone(e) {
        const msg ="確定刪除該項事件?"
        if(!e.target.matches("input[type="button"]")) return; // 只有復選框才可以執(zhí)行事件
        const el = e.target;
        const index = el.dataset.index;
        if(confirm(msg)){
            items.splice(index,1); //將選中數(shù)組刪除
            localStorage.setItem("items", JSON.stringify(items));
            populateList(items, container);
        }else{
            return;
        }
    }
    container.addEventListener("click", deleteDone);
    

    其實最關鍵的就一句話,

    items.splice(index,1); //將選中數(shù)組刪除
    

    玩的就是數(shù)組,這個例子雖然簡單用的卻是MVC的思想。

    接下來我們再看看切換任務狀態(tài),

    //切換checked狀態(tài)
    function toggleDone(e) {
        if(!e.target.matches("input[type="checkbox"]")) return; // 只有復選框才可以執(zhí)行事件
        const el = e.target;
        const index = el.dataset.index;
        items[index].done =!items[index].done;
        localStorage.setItem("items", JSON.stringify(items));
        populateList(items, container);
    }
    container.addEventListener("click", toggleDone);
    

    我們結合著本地存儲的數(shù)據(jù)結構看,這樣就更好理解。

    切換狀態(tài)其實就是對應的數(shù)組值取反。

    好了,到現(xiàn)在為止,我們看看整體代碼:

    完整代碼如下:

    import style from "./main.css";
    const add = document.querySelector(".add-item");//找到添加事件的變表單,之所以需要監(jiān)聽form而不是input是因為這樣用戶回車時也會觸發(fā)事件
    const container = document.querySelector(".item");//找到將事項加入的元素
    var items = JSON.parse(localStorage.getItem("items")) || [];
    
    //        將添加的待辦事件push進items數(shù)組中
    function addItem(e){
        e.preventDefault();  //阻止表單提交的默認行為
        const text = (this.querySelector("[name=item]")).value;
        const item ={
            text,
            done: false
        };
        items.push(item);
        populateList(items, container);
        localStorage.setItem("items", JSON.stringify(items));
        this.reset();
    }
    
    //      將items數(shù)組中的事件添加到html頁面中
    function populateList(plate, plateList) {
        plateList.innerHTML=plate.map( (item, i) => {
            return`
            
  • ${item.text}
  • ` }).join(""); } // 切換checked狀態(tài) function toggleDone(e) { if(!e.target.matches("input[type="checkbox"]")) return; // 只有復選框才可以執(zhí)行事件 const el = e.target; const index = el.dataset.index; items[index].done =!items[index].done; localStorage.setItem("items", JSON.stringify(items)); populateList(items, container); } // 刪除事件 function deleteDone(e) { const msg ="確定刪除該項事件?" if(!e.target.matches("input[type="button"]")) return; // 只有復選框才可以執(zhí)行事件 const el = e.target; const index = el.dataset.index; if(confirm(msg)){ items.splice(index,1); //將選中數(shù)組刪除 localStorage.setItem("items", JSON.stringify(items)); populateList(items, container); }else{ return; } } add.addEventListener("submit", addItem); container.addEventListener("click", toggleDone); container.addEventListener("click", deleteDone); populateList(items, container);

    寫完了上線

    npm run build
    
    
    

    好,我們總結一下:

    1.不要陷入到開發(fā)環(huán)境里,我們是學習ES6,而不是webpack,所以直接用我寫的webpack工作流就好。

    2.要會寫這個項目的html和css,注意實際項目中css的引入方式。

    3.學習mvc的思想,嘗試使用通過修改數(shù)組的方式實現(xiàn)任務的增加、刪除和修改功能。

    4.掌握本地存儲的用法。

    好,本文就到這里,下節(jié)課我們再做一個更貼近工作的例子。

    文章版權歸作者所有,未經(jīng)允許請勿轉載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。

    轉載請注明本文地址:http://m.specialneedsforspecialkids.com/yun/109695.html

    相關文章

    • Day15 - LocalStorage

      摘要:完整中文版指南及視頻教程在從零到壹全棧部落。當頁面重新刷新或者關閉之前,執(zhí)行清除頁面的緩存。慎用,尤其在生產(chǎn)環(huán)境中。 Day15 - LocalStorage (Node+Vue+微信公眾號開發(fā))企業(yè)級產(chǎn)品全棧開發(fā)速成周末班首期班(10.28號正式開班,歡迎搶座) 作者:?黎躍春-追時間的人 簡介:JavaScript30 是 Wes Bos 推出的一個 30 天挑戰(zhàn)。項目免費提供了 ...

      用戶84 評論0 收藏0
    • 如何使用React Hooks建立一個待辦事項列表

      摘要:構建事項列表待辦事項清單是使用廣泛的例子,理由很充分它們是很棒的練習工具。對表單使用我們的表單應該跟蹤的值并在保存提交時執(zhí)行方法。記得敲哦對事項列表使用我們的事項列表也需要。在中傳遞這個函數(shù)我們使用方法把所有不符合的事項保存下來。 原文地址:How to Build a Todo List with React Hooks showImg(https://segmentfault.c...

      waruqi 評論0 收藏0
    • todolist--初學者練習使用vuejs方法

      摘要:我們都知道,現(xiàn)在的前端開發(fā)的最火的三大框架之一,它極大地方便了我們的前端工作者的工作,這是筆者整理的一份用寫的一個的整個過程。 我們都知道,現(xiàn)在Vuejs的前端開發(fā)的最火的三大框架之一,它極大地方便了我們的前端工作者的工作,這是筆者整理的一份用vue寫的一個todolist的整個過程。 1.新建一個文件夾,配置環(huán)境變量 安裝的命令行有: npm init -y npm i -S tod...

      NSFish 評論0 收藏0
    • React + Ramda: 函數(shù)式編程嘗鮮

      摘要:每當?shù)闹蹈淖兒螅覀冎恍枰匦抡{(diào)用方法即可現(xiàn)在,讓我們來實現(xiàn)一個類似風格的歸約函數(shù),以不斷的遞增。歸約函數(shù)是不允許修改當前狀態(tài)的,所有最簡單的實現(xiàn)方式就是。 原文:Functional Components with React stateless functions and Ramda 閱讀本文需要的知識儲備: 函數(shù)式編程基本概念(組合、柯里化、透鏡) React 基本知識(組件、...

      tomener 評論0 收藏0

    發(fā)表評論

    0條評論

    最新活動
    閱讀需要支付1元查看
    <