成人国产在线小视频_日韩寡妇人妻调教在线播放_色成人www永久在线观看_2018国产精品久久_亚洲欧美高清在线30p_亚洲少妇综合一区_黄色在线播放国产_亚洲另类技巧小说校园_国产主播xx日韩_a级毛片在线免费

資訊專欄INFORMATION COLUMN

react組件的配置和搭建

davidac / 2504人閱讀

摘要:作者基于服務(wù)器的搭建第一步,安裝初始化在創(chuàng)建項(xiàng)目的當(dāng)前文件夾來打開控制臺,進(jìn)行初始化,此步驟會出現(xiàn)的文件,用于加載依賴安裝安裝安裝不成功的話就一個一個安裝安裝在項(xiàng)目里創(chuàng)建文件夾里創(chuàng)建主頁面在項(xiàng)目

作者:yewq

h5.基于服務(wù)器的搭建

第一步,安裝node

react初始化 在創(chuàng)建項(xiàng)目的當(dāng)前文件夾來打開控制臺,進(jìn)行react初始化,npm init,此步驟會出現(xiàn)package.json的文件,用于加載依賴

安裝react,react-dom npm install react react-dom --save

安裝 babel-core、babel-loader、babel-preset-es2015、babel-preset-react npm install babel-core babel-loader babel-preset-es2015 babel-preset-react (安裝不成功的話就一個一個安裝)

安裝webpack-dev-server npm install webpack-dev-server --save-dev

在項(xiàng)目里創(chuàng)建文件夾 dist,dist里創(chuàng)建index.html(主頁面)

在項(xiàng)目里創(chuàng)建文件夾 src,src里創(chuàng)建index.js(相當(dāng)于入口文件)

在項(xiàng)目里創(chuàng)建文件 webpack.config.js

在填充完index.html webpack.config.js index.js內(nèi)容之后,(index.js中的可以先不用引入add.js,先把項(xiàng)目運(yùn)行起來再加組件);在控制臺打入npm start,報錯的話打入npm i -項(xiàng)目所在的磁盤符號 webpack,再執(zhí)行npm start,如果報babel的錯,把loader: "babel"改為loader: "babel-loader",如果報./dist/js/的錯,把路徑改為path: __dirname + "/dist/js",然后就可以運(yùn)行了

h5.index.html的內(nèi)容




    
    Title


    

h5.webpack.config.js的內(nèi)容

module.exports = {
    entry:"./src/index.js",
    output:{
        path: __dirname + "/dist/js",
        filename:"bundle.js"
    },
    devServer:{
        inline:true,
        contentBase:"./dist",
        port:4040
    },
    module:{
        loaders:[
            {
                test:/.js$/,
                exclude:/node_modules/,
                loader: "babel-loader",
                query:{
                    presets:["es2015","react"],
                }
            }
        ]
    }
};

h5.index.js的內(nèi)容

import React from "react";
import ReactDOM from "react-dom";
// import Add from "./components/Add";


// ReactDOM.render(
    
//     document.getElementById("app")
// );
window.index=()=>{
    ReactDOM.render(,document.getElementById("app"));

}

h3. 制作一個小例子(react基本的基礎(chǔ)都包含在里面)
h5. 搭建組件

在src里創(chuàng)建components文件夾,創(chuàng)建文件 Add.js(一定要首字母大寫)TodoFooter.js TodoHeader.js TodoItem.js TodoMain.js

在index.js中加 import Add from "./components/Add";

h5. Add.js中的代碼

import React from "react";
// import LocalDb from "localDb";

import TodoHeader from "./TodoHeader.js";
import TodoMain from "./TodoMain.js";
import TodoFooter from "./TodoFooter.js";

class Add extends React.Component {
    constructor(){
        super();
        // this.db = new LocalDb("React-Todos");
        this.state = {
            todos: [
                {
                    text: "地下城堡",
                    isDone: false
                },
                {
                    text: "問道",
                    isDone: false
                },
                 {
                    text:"不思議",
                    isDone: false
                }
                ],

            isAllChecked: false
        };
    }

    // 判斷是否所有任務(wù)的狀態(tài)都完成,同步底部的全選框
    allChecked(){
        let isAllChecked = false;
        if(this.state.todos.every((todo)=> todo.isDone)){
            isAllChecked = true;
            this.setState({
                todos: this.state.todos,
                isAllChecked:true
            });
        }else{
            this.setState({
                todos: this.state.todos,
                isAllChecked:false
            });
        }
        this.setState({
            todos: this.state.todos,
        });
        
    }

    // 添加任務(wù),是傳遞給Header組件的方法
    addTodo(todoItem){
        this.state.todos.push(todoItem);
        this.allChecked();
    }

    // 改變?nèi)蝿?wù)狀態(tài),傳遞給TodoItem和Footer組件的方法
    changeTodoState(index, isDone, isChangeAll = false){
        if(isChangeAll){
            this.setState({
                todos: this.state.todos.map((todo) => {
                    todo.isDone = isDone;
                    return todo;
                }),
                isAllChecked:isDone
            })
            this.allChecked();
        }else{
            this.state.todos[index].isDone = isDone;
            this.allChecked();
        }
    }
    // 清除已完成的任務(wù),傳遞給Footer組件的方法
    clearDone(){
        let todos = this.state.todos.filter(todo => !todo.isDone);
        this.setState({
            todos: todos,
            isAllChecked: false
        });
    }

    // 刪除當(dāng)前的任務(wù),傳遞給TodoItem的方法
    deleteTodo(index){
        this.state.todos.splice(index, 1);
        this.setState({
            todos: this.state.todos
        });
    }
    render(){
        var props = {
            todoCount: this.state.todos.length || 0,
            todoDoneCount: (this.state.todos && this.state.todos.filter((todo)=>todo.isDone)).length || 0
        };
        return (
            
) } } export default Add;

h5. TodoHeader.js中的代碼

import React from "react";

class TodoHeader extends React.Component {

    // 綁定鍵盤回車事件,添加新任務(wù)
    handlerKeyUp(event){
        if(event.keyCode === 13){
            let value = event.target.value;

            if(!value) return false;

            let newTodoItem = {
                text: value,
                isDone: false
            };
            event.target.value = "";
            this.props.addTodo(newTodoItem);
        }
    }
    render(){
        return (
            
) } } export default TodoHeader;

h5. TodoFooter.js中的代碼

import React from "react";
export default class TodoFooter extends React.Component{

    // 處理全選與全不選的狀態(tài)
    handlerAllState(event){
        this.props.changeTodoState(null, event.target.checked, true);
    }

    // 綁定點(diǎn)擊事件,清除已完成
    handlerClick(){
        this.props.clearDone();
    }

    render(){
        return (
            
{this.props.todoDoneCount}已完成 / {this.props.todoCount}總數(shù)
) } }

h5. TodoItem.js中的代碼

import React from "react";
export default class TodoItem extends React.Component{

    // 處理任務(wù)是否完成狀態(tài)
    handlerChange(){
        let isDone = !this.props.isDone;
        this.props.changeTodoState(this.props.index, isDone);
    }

    // 鼠標(biāo)移入
    handlerMouseOver(){
        this.refs.deleteBtn.style.display = "inline";
    }

    // 鼠標(biāo)移出
    handlerMouseOut(){
        this.refs.deleteBtn.style.display = "none";
    }

    // 刪除當(dāng)前任務(wù)
    handlerDelete(){
        this.props.deleteTodo(this.props.index);
    }

    render(){
        let doneStyle = this.props.isDone ? {textDecoration: "line-through"} : {textDecoration: "none"};

        return (
            
  • {this.props.text}
  • ) } }

    h5. TodoMain.js中的代碼

    import React from "react";
    import TodoItem from "./TodoItem.js"
    
    export default class TodoMain extends React.Component{
        // 遍歷顯示任務(wù),轉(zhuǎn)發(fā)props
        render(){
            return (
                
      {this.props.todos.map((todo, index) => { return })}
    ) }

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

    轉(zhuǎn)載請注明本文地址:http://systransis.cn/yun/92301.html

    相關(guān)文章

    • 搭建腳手架到在npm上發(fā)布react組件

      摘要:從搭建腳手架到在上發(fā)布組件最近公司給公司里架設(shè)了私有的倉庫,相應(yīng)地也需要一個用來發(fā)布組件用的腳手架,在這個過程中又又又又復(fù)習(xí)了一下,在這里分享下腳手架搭建的過程。 從搭建腳手架到在npm上發(fā)布react組件 最近公司給公司里架設(shè)了私有的npm倉庫,相應(yīng)地也需要一個用來發(fā)布react組件用的腳手架,在這個過程中又又又又復(fù)習(xí)了一下webpack,在這里分享下腳手架搭建的過程。 首先,我們預(yù)...

      junfeng777 評論0 收藏0
    • React+TypeScript+Mobx+AntDesignMobile進(jìn)行移動端項(xiàng)目搭建

      摘要:通過裝飾器或者利用時調(diào)用的函數(shù)來進(jìn)行使用下面代碼中當(dāng)或者發(fā)生變化時,會監(jiān)聽數(shù)據(jù)變化確保通過觸發(fā)方法自動更新。只能影響正在運(yùn)行的函數(shù),而無法影響當(dāng)前函數(shù)調(diào)用的異步操作參考官方文檔用法裝飾器函數(shù)遵循中標(biāo)準(zhǔn)的綁定規(guī)則。 前言: 本文基于React+TypeScript+Mobx+AntDesignMobile技術(shù)棧,使用Create-React-App腳手架進(jìn)行一個移動端項(xiàng)目搭建,主要介紹項(xiàng)...

      lindroid 評論0 收藏0
    • 通過create-react-app從零搭建react環(huán)境

      摘要:通過文件可以對圖標(biāo)名稱等信息進(jìn)行配置。注意,注冊的只在生產(chǎn)環(huán)境中生效,并且該功能只有在下才能有效果該文件是過濾文件配置該文件是描述文件定義了項(xiàng)目所需要的各種模塊,以及項(xiàng)目的配置信息比如名稱版本許可證等元數(shù)據(jù)。 一、 快速開始: 全局安裝腳手架: $ npm install -g create-react-app 通過腳手架搭建項(xiàng)目: $ create-react-app 開始項(xiàng)目: ...

      Cympros 評論0 收藏0
    • 通過create-react-app從零搭建react環(huán)境

      摘要:通過文件可以對圖標(biāo)名稱等信息進(jìn)行配置。注意,注冊的只在生產(chǎn)環(huán)境中生效,并且該功能只有在下才能有效果該文件是過濾文件配置該文件是描述文件定義了項(xiàng)目所需要的各種模塊,以及項(xiàng)目的配置信息比如名稱版本許可證等元數(shù)據(jù)。 一、 快速開始: 全局安裝腳手架: $ npm install -g create-react-app 通過腳手架搭建項(xiàng)目: $ create-react-app 開始項(xiàng)目: ...

      CoyPan 評論0 收藏0
    • 從 0 到 1 再到 100, 搭建、編寫、構(gòu)建一個前端項(xiàng)目

      摘要:從到再到搭建編寫構(gòu)建一個前端項(xiàng)目選擇現(xiàn)成的項(xiàng)目模板還是自己搭建項(xiàng)目骨架搭建一個前端項(xiàng)目的方式有兩種選擇現(xiàn)成的項(xiàng)目模板自己搭建項(xiàng)目骨架。使用版本控制系統(tǒng)管理源代碼項(xiàng)目搭建好后,需要一個版本控制系統(tǒng)來管理源代碼。 從 0 到 1 再到 100, 搭建、編寫、構(gòu)建一個前端項(xiàng)目 1. 選擇現(xiàn)成的項(xiàng)目模板還是自己搭建項(xiàng)目骨架 搭建一個前端項(xiàng)目的方式有兩種:選擇現(xiàn)成的項(xiàng)目模板、自己搭建項(xiàng)目骨架。 ...

      call_me_R 評論0 收藏0

    發(fā)表評論

    0條評論

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