webpack react 在瀏覽器報錯:Uncaught ReferenceError: React is not defined

問題出在webpack.config.js內(nèi)容

'use strict';
module.exports = {
    entry: [
        'webpack/hot/dev-server',
        'webpack-dev-server/client?http://localhost:8080',
        './src/components/index/app.js'
    ],
    output: {
        path: './build/',
        filename: 'bundle.js'
    },
    externals: {
        'react': 'React'
    },
    module: {
        loaders: [
            { test: /\.js$/, loader: 'jsx!babel', include: /src/}
        ]
    }
};

這里的externals:{'react':'React'}會將React賦給交給windows.React.而且給commonJS的require('React')用(注意不是require('react'))。

在代碼里使用import而不是require的話就會在瀏覽器報錯了虏冻。(請忽略長長的代碼)

'use strict';
import React from 'react';
import LocalDb from 'localDb';
import TodoHeader from './TodoHeader';
import TodoMain from './TodoMain';
import TodoFooter from './TodoFooter';


/**
 * 從上面的渲染(render)方法可以看出扁誓,組件的結(jié)構(gòu)分為三部分躬窜,就是上中下挤庇。
 * 上面的TodoHeader是用來輸入任務的地方,中間的TodoMain是用來展示任務列表的,
 * 下面的TodoFooter提供一些特殊的方法百拓,比如全選泥彤、刪除等。
 */

class App extends React.Component{
    constructor(){
        super();
        this.db = new LocalDb('ReactDemo');
        //定義組件狀態(tài)
        this.state  ={
            todos:this.db.get('todos') || [],
            isAllChecked:false
        };
    }

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

// 添加任務昔瞧,是傳遞給Header組件的方法
    addTodo(todoItem){
        this.state.todos.push(todoItem);
        this.db.set('todos',this.state.todos);
        this.allChecked();

    }

// 刪除當前的任務指蚁,傳遞給TodoItem的方法
    deleteTodo(index){
        this.state.todos.splice(index,1);
        this.setState({todos:this.state.todos});
        this.db.set('todos',this.state.todos);
    }

// 清除已完成的任務,傳遞給Footer組件的方法
    clearDone(){
        let todos = this.state.todos.filter(todo => !todo.isDone);
        this.setState({
            todos:todos,
            isAllChecked:false
        });
        this.db.set('todos',todos);
    }

// 改變?nèi)蝿諣顟B(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
            });
        }else{
            this.state.todos[index].isDone = isDone;
            this.allChecked();
        }
        this.db.set('todos',this.state.todos);
    }

//組件渲染方法
    render(){
        let info = {
            isAllChecked:this.state.isAllChecked,
            todoCount:this.state.todos.length || 0,
            todoDoneCount:(this.state.todos && this.state.todos.filter((todo)=>todo.isDone)).length || 0
        };
        return (
        <div className="todo-wrap">
            <TodoHeader addTodo={this.addTodo.bind(this)} />
            <TodoMain todos={this.state.todos} deleteTodo={this.deleteTodo.bind(this)} changeTodoState={this.changeTodoState.bind(this)} />
            <TodoFooter {...info} changeTodoState={this.changeTodoState.bind(this)} clearDone={this.clearDone.bind(this)} />
        </div>
    );
    }
}

React.render(<App/>,document.getElementById('app'));

stackoverflow這里解釋得更清楚

最后編輯于
?著作權歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末凝化,一起剝皮案震驚了整個濱河市,隨后出現(xiàn)的幾起案子酬荞,更是在濱河造成了極大的恐慌搓劫,老刑警劉巖,帶你破解...
    沈念sama閱讀 217,542評論 6 504
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件混巧,死亡現(xiàn)場離奇詭異枪向,居然都是意外死亡,警方通過查閱死者的電腦和手機牲剃,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,822評論 3 394
  • 文/潘曉璐 我一進店門遣疯,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人凿傅,你說我怎么就攤上這事缠犀。” “怎么了聪舒?”我有些...
    開封第一講書人閱讀 163,912評論 0 354
  • 文/不壞的土叔 我叫張陵辨液,是天一觀的道長。 經(jīng)常有香客問我箱残,道長滔迈,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 58,449評論 1 293
  • 正文 為了忘掉前任被辑,我火速辦了婚禮燎悍,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘盼理。我一直安慰自己谈山,他們只是感情好,可當我...
    茶點故事閱讀 67,500評論 6 392
  • 文/花漫 我一把揭開白布宏怔。 她就那樣靜靜地躺著奏路,像睡著了一般。 火紅的嫁衣襯著肌膚如雪臊诊。 梳的紋絲不亂的頭發(fā)上鸽粉,一...
    開封第一講書人閱讀 51,370評論 1 302
  • 那天,我揣著相機與錄音抓艳,去河邊找鬼触机。 笑死,一個胖子當著我的面吹牛,可吹牛的內(nèi)容都是我干的威兜。 我是一名探鬼主播销斟,決...
    沈念sama閱讀 40,193評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼椒舵!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起约谈,我...
    開封第一講書人閱讀 39,074評論 0 276
  • 序言:老撾萬榮一對情侶失蹤笔宿,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后棱诱,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體泼橘,經(jīng)...
    沈念sama閱讀 45,505評論 1 314
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 37,722評論 3 335
  • 正文 我和宋清朗相戀三年迈勋,在試婚紗的時候發(fā)現(xiàn)自己被綠了炬灭。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 39,841評論 1 348
  • 序言:一個原本活蹦亂跳的男人離奇死亡靡菇,死狀恐怖重归,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情厦凤,我是刑警寧澤鼻吮,帶...
    沈念sama閱讀 35,569評論 5 345
  • 正文 年R本政府宣布,位于F島的核電站较鼓,受9級特大地震影響椎木,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜博烂,卻給世界環(huán)境...
    茶點故事閱讀 41,168評論 3 328
  • 文/蒙蒙 一香椎、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧禽篱,春花似錦畜伐、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,783評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至肥照,卻和暖如春脚仔,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背舆绎。 一陣腳步聲響...
    開封第一講書人閱讀 32,918評論 1 269
  • 我被黑心中介騙來泰國打工鲤脏, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人。 一個月前我還...
    沈念sama閱讀 47,962評論 2 370
  • 正文 我出身青樓猎醇,卻偏偏與公主長得像窥突,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子硫嘶,可洞房花燭夜當晚...
    茶點故事閱讀 44,781評論 2 354

推薦閱讀更多精彩內(nèi)容

  • 目錄第1章 webpack簡介 11.1 webpack是什么阻问? 11.2 官網(wǎng)地址 21.3 為什么使用 web...
    lemonzoey閱讀 1,735評論 0 1
  • webpack 介紹 webpack 是什么 為什么引入新的打包工具 webpack 核心思想 webpack 安...
    yxsGert閱讀 6,464評論 2 71
  • 無意中看到zhangwnag大佬分享的webpack教程感覺受益匪淺,特此分享以備自己日后查看沦疾,也希望更多的人看到...
    小小字符閱讀 8,164評論 7 35
  • GitChat技術雜談 前言 本文較長称近,為了節(jié)省你的閱讀時間,在文前列寫作思路如下: 什么是 webpack哮塞,它要...
    蕭玄辭閱讀 12,693評論 7 110
  • 構(gòu)建一個小項目——FlyBird刨秆,學習webpack和react。(本文成文于2017/2/25) 從webpac...
    布蕾布蕾閱讀 16,821評論 31 98