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

資訊專欄INFORMATION COLUMN

React-APP結(jié)合webpack搭建項目

jayzou / 2327人閱讀

摘要:搭建項目有三種安裝的方式,想了解的登錄官網(wǎng)查看,今天介紹的一個自動安裝的不需要怎么配置環(huán)境,自動生成的方式,類似于并實現(xiàn)一個小案例,留言功能官網(wǎng)的安裝教程安裝依次安裝最終啟動自后會出現(xiàn)一個頁面大家可以去試試下邊我們配置一

React-APP搭建項目

React有三種安裝的方式,想了解的登錄React官網(wǎng)查看,今天介紹的一個自動安裝的不需要怎么配置環(huán)境,自動生成的方式,類似于vue-cli!并實現(xiàn)一個小案例,留言功能!

官網(wǎng)的安裝教程!

安裝react-app
//依次安裝
npm install -g create-react-app
create-react-app my-app

cd my-app
npm start

最終啟動自后會出現(xiàn)一個Welcome React頁面,
大家可以去試試.

下邊我們配置一下項目結(jié)構(gòu)

安裝我們需要的loader
npm file-loader url url-loader --save-dev
配置webpack
rules: [
     {test: /.js$/, exclude: /node_modules/, loader: "react-hot-loader!babel-loader"},
     {test: /.css$/, exclude: /node_modules/, loader: "style-loader!css-loader"},
     { test: /.eot(?v=d+.d+.d+)?$/, loader: "file-loader" },
     { test: /.(woff|woff2)$/, loader:"url-loader?prefix=font/&limit=5000" },
     { test: /.ttf(?v=d+.d+.d+)?$/, loader: "url-loader?limit=10000&mimetype=application/octet-stream" },
     { test: /.svg(?v=d+.d+.d+)?$/, loader: "url-loader?limit=10000&mimetype=image/svg+xml" }
  ]
復(fù)制之前的webpack.config.js文件

我們加以改造

module.exports = {
  entry: "./index.js",
  output: {
    path:path.resolve(__dirname,"build"),
    publicPath:"/assets/",
    filename: "bundle.js"
  },
  module: {
      rules: [
    { test: /.js$/, exclude: /node_modules/, loader: "react-hot-loader!babel-loader" },
    { test: /.css$/, exclude: /node_modules/, loader: "style-loader!css-loader" },
    { test: /.eot(?v=d+.d+.d+)?$/, loader: "file-loader" },  //添加
    { test: /.(woff|woff2)$/, loader:"url-loader?prefix=font/&limit=5000" }, //添加
    { test: /.ttf(?v=d+.d+.d+)?$/, loader: "url-loader?limit=10000&mimetype=application/octet-stream" }, //添加
    { test: /.svg(?v=d+.d+.d+)?$/, loader: "url-loader?limit=10000&mimetype=image/svg+xml" } //添加
      ]
    } 
}    
導(dǎo)入我們之前的json文件
{
  "name": "myapp",
  "version": "0.1.0",
  "private": true,
  "dependencies": {
    "antd-mobile": "^1.5.0",
    "react": "^15.6.1",
    "react-dom": "^15.6.1",
    "react-scripts": "1.0.10"
  },
  "scripts": {
    "start": "react-scripts start",
    "build": "react-scripts build",
    "test": "react-scripts test --env=jsdom",
    "eject": "react-scripts eject"
  },
  "devDependencies": {
    "babel-plugin-import": "^1.2.1",
    "node-sass": "^4.5.3",
    "sass-loader": "^6.0.6"
  }
}
輸入npm install補全我們的項目結(jié)構(gòu)
npm install
引入bootstap模塊

我們的bootstap是事先安裝完成之后,把他移動到css項目目錄下的,index配置如下

//入口文件index.js下
import React from "react";
import ReactDOM from "react-dom";
import LiuYanapp from "./LiuYanapp";

import "./bootstrap/css/bootstrap.min.css";  //引入樣式文件
ReactDOM.render(,document.getElementById("app"));      //輸出到頁面
創(chuàng)建留言模板,并劃分項目模塊

import React from "react";

import LiuYanList from "./LiuYanList";
import LiuYanForm from "./LiuYanForm";

class LiuYanapp extends React.Component{
    constructor(props){
        super(props);
        this.ids=1;
        this.state={
                todos:[]
        };
        
        this.addItem=this.addItem.bind(this);
        this.deleteItem=this.deleteItem.bind(this);
    }
    deleteItem(id){
        let newtodos=this.state.todos.filter((item)=>{
            return !(item.id==id)
        });
          this.setState({
            todos:newtodos
        });

    }

    addItem(value){
       this.state.todos.unshift(
            {
                id:this.ids++,
                text:value,
                time:(new Date()).toLocaleString(),
                done:0
            }
       )
        this.setState({
            todos:this.state.todos
        });   
    }

    render(){
        return (
            





留言板

); } } export default LiuYanapp;
創(chuàng)建LiuYanForm.js文件
import React from "react";

class LiuYanForm extends React.Component{
   tijiao(event){
        event.preventDefault();
    }
    add(event){        
        if(event.type=="keyup"&&event.keyCode!=13){
            return false;
        }
        let txt=this.refs.txt.value;
        if(txt=="") return false;       
        this.props.addItem(txt);
        this.refs.txt.value="";
    }
    render(){
        return(
             
); } } export default LiuYanForm;
創(chuàng)建LiuYanItem.js文件
import React from "react";

class LiuYanItem extends React.Component{
    delete(){
        this.props.deleteItem(this.props.data.id);
    }
    render(){

        let {text,time,done,id}=this.props.data;

        return (
           
               {text}
                   

{time} 刪除留言 ); } } export default LiuYanItem;
創(chuàng)建LiuYanList.js文件
import React from "react";

import LiuYanItem from "./LiuYanItem";
class LiuYanList extends React.Component{
    render(){
        let todos=this.props.data;
       
        let todoItems=todos.map(item=>{
            return 
        });
        
        return (
            
                    {todoItems}
                
留言
); } } export default LiuYanList;

這樣我們的留言功能就創(chuàng)建完了,大家輸入npm start就可以對項目進(jìn)行啟動!想了解的同學(xué)們可以復(fù)制回去實驗一下!

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

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

相關(guān)文章

  • 通過create-react-app從零搭建react環(huán)境

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

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

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

    CoyPan 評論0 收藏0
  • webpack4 + react 搭建多頁面應(yīng)用

    摘要:升級到之后還沒好好的同步一個可實用的架子,接下來用來搭建一個簡單的的多界面應(yīng)用,廢話不說直接擼碼創(chuàng)建工程目錄結(jié)構(gòu)工程目錄結(jié)構(gòu)配置安裝依賴引入打開瀏覽器配置文件合并基礎(chǔ)配置一些路徑配置設(shè)置開發(fā)環(huán)境 webpack 升級到4之后還沒好好的同步一個可實用的webpack架子,接下來用webpack4來搭建一個簡單的react的多界面應(yīng)用,廢話不說 直接擼碼 創(chuàng)建工程 $ mkdir dem...

    nifhlheimr 評論0 收藏0
  • webpack4 + react 搭建多頁面應(yīng)用

    摘要:升級到之后還沒好好的同步一個可實用的架子,接下來用來搭建一個簡單的的多界面應(yīng)用,廢話不說直接擼碼創(chuàng)建工程目錄結(jié)構(gòu)工程目錄結(jié)構(gòu)配置安裝依賴引入打開瀏覽器配置文件合并基礎(chǔ)配置一些路徑配置設(shè)置開發(fā)環(huán)境 webpack 升級到4之后還沒好好的同步一個可實用的webpack架子,接下來用webpack4來搭建一個簡單的react的多界面應(yīng)用,廢話不說 直接擼碼 創(chuàng)建工程 $ mkdir dem...

    wushuiyong 評論0 收藏0

發(fā)表評論

0條評論

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