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

資訊專欄INFORMATION COLUMN

WebPack+React.Js+BootStrap 實現(xiàn)進制轉(zhuǎn)換工具

Y3G / 747人閱讀

摘要:的作用是獲取用戶輸入的數(shù)據(jù),當輸入框的值發(fā)生改變時,對應的事件響應會被調(diào)用也就是函數(shù),其對進行了設置,并內(nèi)部有回調(diào)函數(shù)告訴父級組件有屬性發(fā)生變化。于是我們就在這個函數(shù)中調(diào)用進制轉(zhuǎn)換的函數(shù)并把結(jié)果呈現(xiàn)出來,這樣就實現(xiàn)了數(shù)據(jù)的傳遞功能了。

一.WebPack入門 1.WebPack簡介

WebPack是模塊打包機:分析項目結(jié)構(gòu),找到JavaScript模塊以及其它的一些瀏覽器不能直接運行的拓展語言(Scss,TypeScript等),并將其打包為合適的格式以供瀏覽器使用。

2.如何使用WebPack

1.安裝:

(1)全局安裝:

    
    npm install -g webpack

(2)安裝到項目中:

    
    npm install --save-dev webpack

2.配置使用:

(1)項目的目錄結(jié)構(gòu):

(2)目錄解析:

在項目目錄中創(chuàng)建兩個文件夾,一個是app,另一個是public.接著再創(chuàng)建一個文件index.html放置在public中。public用于放置頁面的入口文件,app用來放置js文件。

(3)WebPack的配置文件(webpack.config.js):

    module.exports = {
        entry:  __dirname + "/app/main.js",//唯一入口文件
        output: {
            path: __dirname + "/public",//打包后文件bundle.js存放的地方
            filename: "bundle.js"http://打包后輸出文件的文件名
        }
    }

3.生成Source Maps(使調(diào)試更容易)

(1)Source Maps是Webpack在打包時可以為我們生成的source maps,為我們提供了一種對應編譯 文件和源文件的方法,使得編譯后的代碼可讀性更高,也更容易調(diào)試。在webpack的配置文件中配置 source maps,需要配置devtool

(2)devetool配置選項優(yōu)缺點

*上述選項由上到下打包速度越來越快,不過同時也具有越來越多的負面作用,較快的構(gòu)建速度的后果        就是對打包后的文件的的執(zhí)行有一定影響。*

(3)WebPack的配置文件(webpack.config.js):

    module.exports = {
        devetool:"eval-source-map",//配置Source Maps選項,選擇合適的選項
        entry:  __dirname + "/app/main.js",//唯一入口文件
        output: {
            path: __dirname + "/public",//打包后文件bundle.js存放的地方
            filename: "bundle.js"http://打包后輸出文件的文件名
        }
    }
3.使用webpack-server實時監(jiān)測代碼并刷新

1.安裝:

    
    npm install --save-dev webpack-dev-server

2.WebPack的配置文件(webpack.config.js)

    module.exports = {
        devetool:"eval-source-map",//配置Source Maps選項,選擇合適的選項
        entry:  __dirname + "/app/main.js",//唯一入口文件
        output: {
            path: __dirname + "/public",//打包后文件bundle.js存放的地方
            filename: "bundle.js"http://打包后輸出文件的文件名
        }

        devServer: {
            port: 8080,//設置服務器監(jiān)聽的端口,默認是8080
        contentBase: "./public",//本地服務器所加載的頁面所在的目錄
        colors: true,//終端中輸出結(jié)果是否為彩色
        historyApiFallback: true,//是否使用不跳轉(zhuǎn),一般是在開發(fā)單頁面應用比較有優(yōu)勢
        inline: true//是否開啟實時刷新
      }
    }
4.使用Loaders處理加載文件

1.安裝:

    npm install --save-dev json-loader

2.配置文件(webpack.config.js):

    module.exports = {
        devtool: "eval-source-map",
        entry:  __dirname + "/app/main.js",
            path: __dirname + "/public",
        filename: "bundle.js"
        },

        module: {//在配置文件里添加JSON loader
        loaders: [
                {
            test: /.json$/,//匹配.json類型的文件
            loader: "json"
                }
        ]
        },
      
        devServer: {
        contentBase: "./public",
        colors: true,
        historyApiFallback: true,
        inline: true
        }
    }

*這樣一來,就可以通過在js文件代碼中引入json格式的文件。*

    import config from "./config.json"
    console.log(config.text);
5.使用Babel轉(zhuǎn)換JavaScript語言標準

1.安裝:

    //一次性安裝多個模塊
    npm install --save-dev babel-core babel-loader babel-preset-es2015 babel-preset-react
    npm install --save react react-dom 

2.簡介Babel:

*個人用途是用來解析Es6的語法格式還有JSX的語法,轉(zhuǎn)換后使得瀏覽器能夠使用*

3.配置文件(webpack.config.js):

test: 一個匹配loaders所處理的文件的拓展名的正則表達式(required)

loader: loader的名稱(required)

include/exclude: 手動添加必須處理的文件(文件夾)或屏蔽不需要處理的文件(文件夾)(optional)

query: 為loaders提供額外的設置選項(optional)

    module.exports = {
        devtool: "eval-source-map",
        entry:  __dirname + "/app/main.js",
            path: __dirname + "/public",
        filename: "bundle.js"
        },

        module: {//在配置文件里添加JSON loader
        loaders: [
                {
            test: /.json$/,//匹配.json類型的文件
            loader: "json"
                },
                {
            test: /.js$/,//匹配.js文件
            exclude: /node_modules/,//排除哪個文件不加載
            loader: "babel",//在webpack的module部分的loaders里進行配置即可
            query: {
              presets: ["es2015","react"]
            }
                }
        ]
        },
      
        devServer: {
        contentBase: "./public",
        colors: true,
        historyApiFallback: true,
        inline: true
        }
    }
二.React.Js實現(xiàn)進制轉(zhuǎn)換工具 1.HTML主界面實現(xiàn)

搭建好React的工具平臺之后我們就可以實現(xiàn)工具的制作了^_^

HTML節(jié)目十分簡單,里面就只有一個div容器,還有一個使用bootstrap用來裝飾的導航欄,如此而已。讓我們看一下代碼吧!

index.html:


    
    
        
        
        
        在線進制轉(zhuǎn)換工具
    

    
        
        
2.React組件實現(xiàn)

1.定義兩個React子組件(InputNumber.js,OutputNumber.js),用來后面的視圖調(diào)用

先給出代碼吧!

(1) InputNumber.js:

import React, { Component } from "react"
import {
  Grid,
  Row,
  Col,
  FormControl,
  ControlLabel,
  FormGroup,
  Radio,
  InputGroup,
} from "react-bootstrap"

class InputNumber extends React.Component {
  constructor(props) {
    super(props);
    var checkedList = [false, false, false];
    checkedList[this.props.checked] = true;
    this.state = {
      checkedList: checkedList,
      number: this.props.number
    }
  }
  selectHandleChange(event) {
    var checkedList = [false, false, false];
    checkedList[event.target.value] = true;
    this.setState({
      checkedList: checkedList
    });
    this.props.callbackCheckedChange(event.target.value);
  }
  textHandleChange(event) {
    this.setState({
      number: event.target.value
    });
    this.props.callbackNumberChange(event.target.value);
  }
  render() {
    return (
      
        
          二進制
          十進制
          十六進制
        
        
          
            請輸入:
            
          
        
      
    );
  }
}

export default InputNumber;

在上面的代碼中需要關(guān)注的地方有:

該組件是用于用戶輸入數(shù)值后傳遞數(shù)值的類型和大小到父級組件中,所以其內(nèi)部需要有兩個屬性,checkedList和number。checkedList用來標識當前哪個radio選項框被選中,并當點擊事件發(fā)生時,把value的值進行動態(tài)設置,主要是用到了React的組件狀態(tài)機,通過setState函數(shù)對checkedList進行修改。number的作用是獲取用戶輸入的數(shù)據(jù),當輸入框的值發(fā)生改變時,對應的事件響應會被調(diào)用也就是textHandleChange函數(shù),其對number進行了設置,并內(nèi)部有回調(diào)函數(shù):this.props.callbackCheckedChange(event.target.value)告訴父級組件有屬性發(fā)生變化。這樣就使得當前組件的狀態(tài)改變時,父級的組件也會對應調(diào)用方法進行事件處理。

(2) OutputNumber.js:

import React, { Component } from "react"
import {
  Grid,
  Row,
  Col,
  FormControl,
  ControlLabel,
  FormGroup,
  InputGroup,
} from "react-bootstrap"

class OutputNumber extends React.Component {
  constructor(props) {
    super(props);
    this.state = {
      binaryRes: "",
      decimal: "",
      hexadecimal: "",
      mapBase:[2,10,16]
    }
  }
  changeToDec(numbers, base) {
    var sum = 0;
    var length = numbers.length
    for (let i = 0; i < length; i++) {
      let number = parseInt(numbers[i]);
      sum += Math.pow(base, length - i - 1) * number;
    }
    return sum.toString();
  }
  //十進制轉(zhuǎn)換其他進制
  decChange(numbers, base) {
    var num = parseInt(numbers);
    var str = "";
    var k = parseInt(num);
    var m = num % base;
    while (k >= base) {
      if(m > 9)
        str = String.fromCharCode(0x40 + (m - 9)) + str;
      else
        str = m.toString() + str;
      k = parseInt(k / base);
      m = k % base;
    }
    if(m > 9)
      str = String.fromCharCode(0x40 + (m - 9)) + str;
    else
      str = m.toString() + str;
    return str;
  }
  componentWillReceiveProps(nextProps) {
    var base = this.state.mapBase[nextProps.checked];
    var numberDec = this.changeToDec(nextProps.number,base);
    this.setState({
      binaryRes:this.decChange(numberDec,2),
      decimal:this.decChange(numberDec,10),
      hexadecimal:this.decChange(numberDec,16)
    });
  }
  render() {
    return (
      
        
          
            二進制:
            
          
          
            十進制:
            
          
          
            十六制:
            
          
        
      
    )
  }
}


export default OutputNumber;

這個組件是用來對用戶輸入的類型數(shù)據(jù)進行進制轉(zhuǎn)換并呈現(xiàn)結(jié)果,所以需要binaryRes,decimal,hexadecimal這三個屬性來呈現(xiàn)不同類型進制的結(jié)果,通過changeToDec和decChange這兩個函數(shù)對數(shù)值進行轉(zhuǎn)換得到結(jié)果。可是,我們要在什么時候調(diào)用這兩個函數(shù)進行進制轉(zhuǎn)換呢?這時就需要使用componentWillReceiveProps(nextProps)函數(shù),當父級組件傳遞進來的元素發(fā)生改變時,這個方法會被調(diào)用。于是我們就在這個函數(shù)中調(diào)用進制轉(zhuǎn)換的函數(shù)并把結(jié)果呈現(xiàn)出來,這樣就實現(xiàn)了數(shù)據(jù)的傳遞功能了。

2.定義一個React父級組件用來封裝兩個子組件(MainView.js),用來給入口文件調(diào)用

代碼實現(xiàn)

MainView.js:

import React from "react";
import InputNumber from "./InputNumber"
import OutputNumber from "./OutputNumber"


class MainView extends React.Component {
  constructor(props) {
    super(props);
    this.state = {
      checked: 0,
      number: ""
    }
  }
  onCheckedChange(newChecked) {
    this.setState({
      checked: newChecked,
    });
  }
  onNumberChange(newNumber) {
    this.setState({
      number: newNumber
    });
  }
  render() {
    return (
      
); } } export default MainView;

這個組件是父級組件,封裝了前面的兩個組件,并把其內(nèi)部的屬性統(tǒng)一傳遞給兩個子組件,使得數(shù)據(jù)進行了單向的綁定。

3.定義一個入口文件main.js用來向頁面渲染React組件

代碼實現(xiàn)

main.js:

import React from "react";
import {render} from "react-dom";

import MainView from "./MainView"

var checked = 0;

render(,document.getElementById("root"));    

這代碼不同多說,就是渲染主視圖到虛擬DOM的樹結(jié)構(gòu)中。

三.總結(jié)

一開始看來React的基本用法但是沒有經(jīng)過實際的操作會以為React很簡單,但是當你動手打出代碼的時候,你會發(fā)現(xiàn)很多的問題。這時候就需要我們一步一步地去查資料探索,找到解決的方案并實現(xiàn)。所以我寫這篇文章的目的是為了讓更多React初學者能夠參考并把React學得透徹,我對React也是剛開始入門,還不是很熟練,希望做出更多的東西,寫出更多的總結(jié)不斷提升自己的編程能力,哈哈哈,感謝閱讀此文。

最后附上程序github的倉庫鏈接程序github的倉庫鏈接

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

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

相關(guān)文章

  • 4月份前端資源分享

    摘要:更多資源請文章轉(zhuǎn)自月份前端資源分享關(guān)于的思考一款有趣的動畫效果跨站資源共享之二最流行的編程語言能做什么到底什么是閉包的第三個參數(shù)跨域資源共享詳解阮一峰前端要給力之語句在中的值周愛民中國第二屆視頻花絮編碼規(guī)范前端工程師手冊奇舞周刊被忽視的 更多資源請Star:https://github.com/maidishike... 文章轉(zhuǎn)自:https://github.com/jsfron...

    jsdt 評論0 收藏0
  • 前端學習路線

    摘要:具體來說,包管理器就是可以通過命令行,幫助你把外部庫和插件放到你的項目里面并在之后進行版本升級,這樣就不用手工復制和更新庫?,F(xiàn)在有的包管理器主要是和。 一、基礎(chǔ) 1、學習HTML基礎(chǔ) HTML給你的網(wǎng)頁賦予了結(jié)構(gòu)。它就像是人的骨架那樣讓你保持站立。首先你需要去學習語法以及它必須提供的一切。你的學習應該聚焦在下面這些東西上: 學習HTML基礎(chǔ),了解如何編寫語義HTML 理解如何把網(wǎng)頁分...

    FullStackDeveloper 評論0 收藏0
  • 前端學習路線

    摘要:具體來說,包管理器就是可以通過命令行,幫助你把外部庫和插件放到你的項目里面并在之后進行版本升級,這樣就不用手工復制和更新庫?,F(xiàn)在有的包管理器主要是和。 一、基礎(chǔ) 1、學習HTML基礎(chǔ) HTML給你的網(wǎng)頁賦予了結(jié)構(gòu)。它就像是人的骨架那樣讓你保持站立。首先你需要去學習語法以及它必須提供的一切。你的學習應該聚焦在下面這些東西上: 學習HTML基礎(chǔ),了解如何編寫語義HTML 理解如何把網(wǎng)頁分...

    20171112 評論0 收藏0
  • 前端資源收集整理

    摘要:工作原因,最近一年斷斷續(xù)續(xù)寫了一點前端代碼,收集整理了一些資料,和大家共享。 工作原因,最近一年斷斷續(xù)續(xù)寫了一點前端代碼,收集整理了一些資料,和大家共享。 Github版本:Front-End Resource Collection 前端相關(guān)資源匯總 學習指導 精華文章 Web前端的路該怎么走?:文章超長,但是干貨超級多,值得反復精讀! 聽說2017你想寫前端?:適合于已經(jīng)度過了小白階...

    awesome23 評論0 收藏0

發(fā)表評論

0條評論

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