美文网首页代码web开发h5
Vue2.0 新手完全填坑攻略——从环境搭建到发布

Vue2.0 新手完全填坑攻略——从环境搭建到发布

作者: JinkeyAI | 来源:发表于2016-10-10 23:10 被阅读317022次

    本文作者 Jinkey(微信公众号 jinkey-love,官网 https://jinkey.ai
    原文链接 https://jinkey.ai/post/tech/vue2.0-xin-shou-wan-quan-tian-keng-gong-lue-cong-huan-jing-da-jian-dao-fa-bu
    文章允许非篡改署名转载,删除或修改本段版权信息转载的,视为侵犯知识产权,我们保留追求您法律责任的权利,特此声明!
    感谢 showonneyubang 技术指导
    Demo 地址:
    http://demo.jinkey.io/vue2
    源码:
    https://github.com/Jinkeycode/vue2-example

    什么是 Vue

    Vue 是一个前端框架,特点是
    数据绑定

    比如你改变一个输入框 Input 标签的值,会自动同步更新到页面上其他绑定该输入框的组件的值

    数据绑定

    组件化

    页面上小到一个按钮都可以是一个单独的文件.vue,这些小组件直接可以像乐高积木一样通过互相引用而组装起来

    组件化

    Vue2.0 推荐开发环境


    开发环境解释

    Homebrew 1.0.6(Mac)、Node.js 6.7.0、npm 3.10.3、webpack 1.13.2、vue-cli 2.4.0、Atom 1.10.2

    安装环境

    打开终端运行以下命令

    安装brew

    /usr/bin/ruby -e "$(curl -fsSL https://raw.githubusercontent.com/Homebrew/install/master/install)"
    

    安装 nodejs

    brew install nodejs

    用 npm install npm@3.10.3 更新 npm 版本报错:

    (node:42) fs: re-evaluating native module sources is not supported.

    解决办法:
    在官网下载6.70的安装包再安装一次(刚刚相当于帮你配置好环境变量,现在再安装一次升级到最新的 npm)

    • 好像以前官网的安装包不会自动配置环境变量的,由于我电脑上之前安装过 nodejs 所以环境变量已经配置好了,不知道现在的安装包会不会自动配置环境变量。

    Windows 下直接下载安装包即可

    获取nodejs模块安装目录访问权限

    sudo chmod -R 777 /usr/local/lib/node_modules/
    

    安装淘宝镜像

    npm install -g cnpm --registry=https://registry.npm.taobao.org

    安装webpack

    cnpm install webpack -g

    安装vue脚手架

    npm install vue-cli -g

    在硬盘上找一个文件夹放工程用的,在终端中进入该目录

    Mac

    cd 目录路径

    根据模板创建项目

    vue init webpack-simple 工程名字<工程名字不能用中文>
    或者创建 vue1.0 的项目
    vue init webpack-simple#1.0 工程名字<工程名字不能用中文>

    会有一些初始化的设置,如下输入:
    Target directory exists. Continue? (Y/n)直接回车默认(然后会下载 vue2.0模板,这里可能需要连代理)
    Project name (vue-test)直接回车默认
    Project description (A Vue.js project) 直接回车默认
    Author 写你自己的名字

    cd 命令进入创建的工程目录

    工程目录如图所示:


    安装项目依赖

    一定要从官方仓库安装,npm 服务器在国外所以这一步安装速度会很慢。

    npm install

    不要从国内镜像cnpm安装(会导致后面缺了很多依赖库)

    cnpm install

    安装 vue 路由模块vue-router和网络请求模块vue-resource

    cnpm install vue-router vue-resource --save

    启动项目

    npm run dev

    填坑(以下坑可能由于 vue2.0 导致其他相关编译打包工具没更新导致的)

    【重点】后来发现这些坑是由于 npm 不是最新的版本3.10.2, 用 npm 3.9.5就会出现以下坑
    解决办法: 请运行以下命令
    npm update -g

    报错

    Error: Cannot find module 'opn'
    Error: Cannot find module 'webpack-dev-middleware'
    Error: Cannot find module 'express'
    Error: Cannot find module 'compression'
    Error: Cannot find module 'sockjs'
    Error: Cannot find module 'spdy'
    Error: Cannot find module 'http-proxy-middleware'
    Error: Cannot find module 'serve-index'

    如果你用的是老版本的 vue-cli 还可能报其他错误,需要更新一下 vue-cli

    npm update vue-cli

    然后可以查看一下当前全局 vue-cli 的版本

    npm view vue-cli

    安装一下这个依赖到工程开发环境

    cnpm install opn --save-dev
    cnpm install webpack-dev-middleware --save-dev
    cnpm install express --save-dev
    cnpm install compression --save-dev
    cnpm install sockjs --save-dev
    cnpm install spdy --save-dev
    cnpm install http-proxy-middleware --save-dev
    cnpm install serve-index --save-dev
    cnpm install connect-history-api-fallback --save-dev

    再启动项目,报错

    ERROR in ./src/main.js
    Module build failed: Error: Cannot find module 'babel-runtime/helpers/typeof'
    at Function.Module._resolveFilename (module.js:440:15)
    at Function.Module._load (module.js:388:25)
    at Module.require (module.js:468:17)
    at require (internal/module.js:20:19)
    at Object.<anonymous> (/Volumes/MacStorage/Coding/Web/vue-test/node_modules/.6.17.0@babel-core/lib/transformation/file/index.js:6:16)
    at Module._compile (module.js:541:32)
    at Object.Module._extensions..js (module.js:550:10)
    at Module.load (module.js:458:32)
    at tryModuleLoad (module.js:417:12)
    at Function.Module._load (module.js:409:3)
    @ multi main
    ERROR in ./~/.2.1.0-beta.8@webpack-dev-server/client/socket.js
    Module not found: Error: Can't resolve 'sockjs-client' in '/Volumes/MacStorage/Coding/Web/vue-test/node_modules/.2.1.0-beta.8@webpack-dev-server/client'
    @ ./~/.2.1.0-beta.8@webpack-dev-server/client/socket.js 1:13-37
    @ ./~/.2.1.0-beta.8@webpack-dev-server/client?http://localhost:8080
    @ multi main

    安装一下 babel-runtime

    cnpm install babel-helpers --save-dev

    启动项目,再次报错

    Module build failed: Error: Cannot find module 'babel-helpers'
    Module build failed: Error: Cannot find module 'babel-traverse'
    Module build failed: Error: Cannot find module 'json5'
    Module build failed: Error: Cannot find module 'babel-generator'
    Module build failed: Error: Cannot find module 'detect-indent'
    Module build failed: Error: Cannot find module 'jsesc'

    找不到依赖那就再安装一下

    cnpm install babel-helpers --save-dev
    cnpm install babel-traverse --save-dev
    cnpm install json5 --save-dev
    ...不写了,请把全部把旧的环境全部清除,更新到最新版本

    解决办法概述

    遇到

    Module build failed: Error: Cannot find module '模块名'

    那就安装

    cnpm install 模块名 --save-dev(关于环境的,表现为npm run dev 启动不了)
    cnpm install 模块名 --save(关于项目的,比如main.js,表现为npm run dev 成功之后控制台报错)
    比如escape-string-regexp、strip-ansi、has-ansi、is-finite、emojis-list

    终于可以启动项目了

    输入完命令会自动启动浏览器,如果默认打开 IE 不行

    npm run dev

    自动启动浏览器就会看到这 帅帅的界面了。


    开始 Vue 之旅

    打开 IDE

    推荐 Atom 打开项目,需要安装 Vue 语法高亮的插件


    使用官网文档学习基础

    我们来看官网的一个例子,(中文文档请自行上网搜索)

    打开 工程目录下的 App.vue
    template 写 html,script写 js,style写样式


    为了方便叙述,我们把官网例子写在同一个组件内
    这里有两个坑:
    第一。一个组件下只能有一个并列的 div,可以这么写,所以复制官网示例的时候只要复制 div 里面的内容就好。

    但是不能这样写:

    第二。数据要写在 return 里面而不是像文档那样子写

    错误的写法:


    这样子可以自己啃完官网文档组件之前的部分了。


    来玩玩组件

    前面讲得基本上都是各种常用组件的数据绑定,下面还得说说的是 Vue 的组件的使用。
    在工程目录/src下创建component文件夹,并在component文件夹下创建一个 firstcomponent.vue并写仿照 App.vue 的格式和前面学到的知识写一个组件。

    <template>
      <div id="firstcomponent">
        <h1>I am a title.</h1>
        <a> written by {{ author }} </a>
      </div>
    </template>
    
    <script type="text/javascript">
    export default {
      data () {
        return {
          author: "微信公众号 jinkey-love"
        }
      }
    }
    </script>
    
    <style>
    </style>
    

    duang... 不能按官网文档那样子叫我做就做,我得先试试再告诉你,我做完效果是这样子的,希望观众做完也是这样子。(迷之微笑 )


    然后在 App.vue 使用组件 ( 因为在 index.html 里面定义了<div id="app"></div>所以就以这个组件作为主入口,方便 )
    第一步,引入。在<script></script>标签内的第一行写

    import firstcomponent from './component/firstcomponent.vue'
    

    第二步,注册。在<script></script>标签内的 data 代码块后面加上 components: { firstcomponent }。记得中间加英文逗号!!!

    export default {
      data () {
        return {
          msg: 'Hello Vue!'
        }
      },
      components: { firstcomponent }
    }
    

    第三步,使用
    <template></template>内加上<firstcomponent></firstcomponent>

    <template>
      <div id="app">
        ![](./assets/logo.png)
        <h1>{{ msg }}</h1>
        <firstcomponent></firstcomponent>
      </div>
    </template>
    

    完成后的代码:


    这时候看看浏览器上的 http://localhost:8080/ 页面(之前打开过就会自动刷新),如果你没看到效果是因为你没有对 App.vuefirstcomponent.vue 进行保存操作,保存后页面会自动刷新。

    使用路由搭建单页应用

    之前已经通过命令安装了vue-router

    cnpm install vue-router --save

    webpack.config.js加入别名

    resolve: {
        alias: {vue: 'vue/dist/vue.js'}
      }
    

    为什么要加 alias 配置项?其作用可以在文档中有相应的描述:


    修改完之后的webpack.config.js是这样子的:

    var path = require('path')
    var webpack = require('webpack')
    
    module.exports = {
      entry: './src/main.js',
      output: {
        path: path.resolve(__dirname, './dist'),
        publicPath: '/dist/',
        filename: 'build.js'
      },
      resolveLoader: {
        root: path.join(__dirname, 'node_modules'),
      },
      module: {
        loaders: [
          {
            test: /\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\.vue$/,
            loader: 'vue'
          },
          {
            test: /\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\.js$/,
            loader: 'babel',
            exclude: /node_modules/
          },
          {
            test: /\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\.(png|jpg|gif|svg)$/,
            loader: 'file',
            query: {
              name: '[name].[ext]?[hash]'
            }
          }
        ]
      },
      resolve: {
        alias: {vue: 'vue/dist/vue.js'}
      },
      devServer: {
        historyApiFallback: true,
        noInfo: true
      },
      devtool: '#eval-source-map'
    }
    
    if (process.env.NODE_ENV === 'production') {
      module.exports.devtool = '#source-map'
      // http://vue-loader.vuejs.org/en/workflow/production.html
      module.exports.plugins = (module.exports.plugins || []).concat([
        new webpack.DefinePlugin({
          'process.env': {
            NODE_ENV: '"production"'
          }
        }),
        new webpack.optimize.UglifyJsPlugin({
          compress: {
            warnings: false
          }
        })
      ])
    }
    

    再按之前的方法写一个组件 secondcomponent.vue

    <template>
      <div id="secondcomponent">
        <h1>I am another page</h1>
        <a> written by {{ author }} </a>
        <p> 感谢 <a href="https://github.com/showonne">showonne</a>大神的技术指导</p>
      </div>
    </template>
    
    <script>
    export default {
      data() {
        return {
          author: "微信公众号 jinkey-love",
          articles: [],
        }
      }
      }
    }
    </script>
    
    <style>
    </style>
    

    这时候修改 main.js,引入并注册 vue-router

    import VueRouter from "vue-router";
    Vue.use(VueRouter);
    

    并且配置路由规则和 app 启动配置项加上 router,旧版的 router.map 方法在 vue-router 2.0 已经不能用了。修改后的main.js如下:

    import Vue from 'vue'
    import App from './App.vue'
    import VueRouter from "vue-router";
    import VueResource from 'vue-resource'
    
    //开启debug模式
    Vue.config.debug = true;
    
    Vue.use(VueRouter);
    Vue.use(VueResource);
    
    // 定义组件, 也可以像教程之前教的方法从别的文件引入
    const First = { template: '<div><h2>我是第 1 个子页面</h2></div>' }
    import secondcomponent from './component/secondcomponent.vue'
    
    // 创建一个路由器实例
    // 并且配置路由规则
    const router = new VueRouter({
      mode: 'history',
      base: __dirname,
      routes: [
        {
          path: '/first',
          component: First
        },
        {
          path: '/second',
          component: secondcomponent
        }
      ]
    })
    
    // 现在我们可以启动应用了!
    // 路由器会创建一个 App 实例,并且挂载到选择符 #app 匹配的元素上。
    const app = new Vue({
      router: router,
      render: h => h(App)
    }).$mount('#app')
    

    这样子改完再打开浏览器看看。


    点击那两个链接试试,会发现<router-view class="view"></router-view>的内容已经展示出来,同时注意浏览器地址已经变更

    另外,也可以把 App.vue 的内容写在 main.js 也是可以的不过不建议这么做


    如果你使用 vue1.0和0.7版本的 vue-router,请参照下面这个教程, 他整个系列都不错的,当然仅限于 vue1.0 :

    http://guowenfh.github.io/2016/03/28/vue-webpack-06-router/

    给页面加点动态数据

    这时候的页面都是静态的(数据在写程序的时候已经固定了不能修改),而每个应用基本上都会请求外部数据以动态改变页面内容。对应有一个库叫 vue-resource 帮我们解决这个问题。
    使用命令行安装

    cnpm install vue-resource --save

    在 main.js 引入并注册 vue-resource:

    import VueResource from 'vue-resource'
    Vue.use(VueResource);
    

    我们在 secondcomponent.vue 上来动态加载数据
    添加一个列表:

    <ul>
          <li v-for="article in articles">
            {{article.title}}
          </li>
        </ul>
    

    在 data 里面加入数组 articles 并赋值为[]
    然后在 data 后面加入加入钩子函数 mounted(详细请参照官方文档关于 vue 生命周期的解析),data 和 mount 中间记得记得加逗号

    mounted: function() {
        this.$http.jsonp('https://api.douban.com/v2/movie/top250?count=10', {}, {
            headers: {
    
            },
            emulateJSON: true
        }).then(function(response) {
          // 这里是处理正确的回调
    
            this.articles = response.data.subjects
            // this.articles = response.data["subjects"] 也可以
    
        }, function(response) {
            // 这里是处理错误的回调
            console.log(response)
        });
      }
    

    这里使用的是豆瓣的公开 GET 接口,如果接口是跨域的 POST 请求,则需要在服务器端配置:

    Access-Control-Allow-Origin: *

    这时候运行看看。等一会接口返回数据,咦,数据加载出来了,棒棒哒 !


    更多 vue-router 的使用方法可以看

    vue-router 0.7
    http://m.doc00.com/doc/1001004eg
    vue-router 2.0
    http://router.vuejs.org/zh-cn/index.html

    来拯救如此难看的界面

    组件、双向绑定、路由、数据请求等基本特性都能用了,写到这里一个单页应用基本上成型了。但是,这几面也太 TM 难看了吧。自己写 UI 框架太费劲?那就上网找一个吧。
    本来想给大家介绍 Vux 的,因为他用的是微信的 WeUI 设计规范,对于开发微信小程序或者微信内的网页非常和谐,但由于写这篇文章的时候 Vux 还不支持 vue2.0,只能用别的框架了。
    命令行安装 ElementUI (此处某公司的人应该发红包了...)

    cnpm install element-ui@next -S

    然后在 main.js 引入并注册

    import Element from 'element-ui'
    import 'element-ui/lib/theme-default/index.css'
    Vue.use(Element)
    

    保存,这时候程序报错

    Uncaught Error: Module parse failed: /Users/**/Desktop/vue2/node_modules/.1.0.0-rc.5@element-ui/lib/theme-default/index.css Unexpected character '@' (1:0)
    You may need an appropriate loader to handle this file type.

    官网文档又有坑了,安装教程也不跟我们说这一步,当我们都是高手了...
    报错是由于我们引入了index.css这个 CSS 文件,但是 webpack 打包的时候无法识别并转换成 js,所以就需要配置才能读取 css 和字体文件,运行命令安装下面三个东西(如果之前安装过就不需要了)

    cnpm install style-loader --save-dev
    cnpm install css-loader --save-dev
    cnpm install file-loader --save-dev

    webpack.config.js 中的 loaders 数组加入以下配置,记得该加逗号的地方加逗号!

    {
        test: /\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\.css$/,
        loader: "style!css"
    },
    {
        test: /\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\.(eot|woff|woff2|ttf)([\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\?]?.*)$/,
        loader: "file"
    }
    

    修改完的 webpack.config.js 如下

    var path = require('path')
    var webpack = require('webpack')
    
    module.exports = {
      entry: './src/main.js',
      output: {
        path: path.resolve(__dirname, './dist'),
        publicPath: '/dist/',
        filename: 'build.js'
      },
      resolveLoader: {
        root: path.join(__dirname, 'node_modules'),
      },
      module: {
        loaders: [
          {
            test: /\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\.vue$/,
            loader: 'vue'
          },
          {
            test: /\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\.js$/,
            loader: 'babel',
            exclude: /node_modules/
          },
          {
              test: /\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\.css$/,
              loader: "style!css"
          },
          {
            test: /\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\.(eot|woff|woff2|ttf)([\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\?]?.*)$/,
            loader: "file"
          },
          {
            test: /\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\.(png|jpg|gif|svg)$/,
            loader: 'file',
            query: {
              name: '[name].[ext]?[hash]'
            }
          }
        ]
      },
      resolve: {
        alias: {vue: 'vue/dist/vue.js'}
      },
      devServer: {
        historyApiFallback: true,
        noInfo: true
      },
      devtool: '#eval-source-map'
    }
    
    if (process.env.NODE_ENV === 'production') {
      module.exports.devtool = '#source-map'
      // http://vue-loader.vuejs.org/en/workflow/production.html
      module.exports.plugins = (module.exports.plugins || []).concat([
        new webpack.DefinePlugin({
          'process.env': {
            NODE_ENV: '"production"'
          }
        }),
        new webpack.optimize.UglifyJsPlugin({
          compress: {
            warnings: false
          }
        })
      ])
    }
    

    给豆瓣的电影列表套个衣服(样式) :

    <el-card class="box-card">
          <div slot="header" class="clearfix">
            <h1 style="line-height: 36px; color: #20A0FF">豆瓣电影排行榜</h2>
          </div>
          <div v-for="article in articles" class="text item">
            {{article.title}}
          </div>
    </el-card>
    

    打开浏览器,输入网址:

    http://localhost:8080/second


    列表比之前漂亮多了,你还可以参照 ElementUI 的文档使用更多组件样式

    http://element.eleme.io/#/component/layout

    编译

    npm run build

    又报错了...orz

    ERROR in build.js from UglifyJs
    SyntaxError: Unexpected token punc «(», expected punc «:» [build.js:32001,6]

    解决办法(21061019 showonne 提交 PR 已合并到主分支)

    cnpm install babel-preset-es2015 --save-dev
    cnpm install babel-preset-stage-0 --save-dev

    然后在项目目录下创建一个.babelrc文件,内容如下:

    {
        presets: ['es2015', 'stage-0']
     }
    

    或者在webpack.config.js中这里

    {
            test: /\\\\.js$/,
            loader: 'babel',
            exclude: /node_modules/
          }
    

    加入 presets 配置,修改成下面酱紫:

    {
            test: /\\\\.js$/,
            loader: 'babel',
            exclude: /node_modules/,
            query: {presets: ['es2015', 'stage-0']
          }
    

    再次执行 npm run build 就可以了,后来发现直接运行 webpack 命令也是可以打包的

    webpack --color --progress

    接着把 index.html 和整个 dist 目录丢到服务器就可以了。

    如果你觉得这篇文章写得好,不需要打赏,你可以下载我朋友做的一个阅读工具,可以订阅公众号和简书、也可以看大神分享的优秀文章。

    下载地址:[

    Jinkey原创
    感谢 showonneyubang 技术指导
    Demo 地址:
    http://demo.jinkey.io/vue2
    源码:
    https://github.com/Jinkeycode/vue2-example

    什么是 Vue

    Vue 是一个前端框架,特点是
    数据绑定

    比如你改变一个输入框 Input 标签的值,会自动同步更新到页面上其他绑定该输入框的组件的值

    数据绑定

    组件化

    页面上小到一个按钮都可以是一个单独的文件.vue,这些小组件直接可以像乐高积木一样通过互相引用而组装起来

    组件化

    Vue2.0 推荐开发环境


    开发环境解释

    Homebrew 1.0.6(Mac)、Node.js 6.7.0、npm 3.10.3、webpack 1.13.2、vue-cli 2.4.0、Atom 1.10.2

    安装环境

    打开终端运行以下命令

    安装brew

    /usr/bin/ruby -e "$(curl -fsSL https://raw.githubusercontent.com/Homebrew/install/master/install)"
    

    安装 nodejs

    brew install nodejs

    用 npm install npm@3.10.3 更新 npm 版本报错:

    (node:42) fs: re-evaluating native module sources is not supported.

    解决办法:
    在官网下载6.70的安装包再安装一次(刚刚相当于帮你配置好环境变量,现在再安装一次升级到最新的 npm)

    • 好像以前官网的安装包不会自动配置环境变量的,由于我电脑上之前安装过 nodejs 所以环境变量已经配置好了,不知道现在的安装包会不会自动配置环境变量。

    Windows 下直接下载安装包即可

    获取nodejs模块安装目录访问权限

    sudo chmod -R 777 /usr/local/lib/node_modules/
    

    安装淘宝镜像

    npm install -g cnpm --registry=https://registry.npm.taobao.org

    安装webpack

    cnpm install webpack -g

    安装vue脚手架

    npm install vue-cli -g

    在硬盘上找一个文件夹放工程用的,在终端中进入该目录

    Mac

    cd 目录路径

    根据模板创建项目

    vue init webpack-simple 工程名字<工程名字不能用中文>
    或者创建 vue1.0 的项目
    vue init webpack-simple#1.0 工程名字<工程名字不能用中文>

    会有一些初始化的设置,如下输入:
    Target directory exists. Continue? (Y/n)直接回车默认(然后会下载 vue2.0模板,这里可能需要连代理)
    Project name (vue-test)直接回车默认
    Project description (A Vue.js project) 直接回车默认
    Author 写你自己的名字

    cd 命令进入创建的工程目录

    工程目录如图所示:


    安装项目依赖

    一定要从官方仓库安装,npm 服务器在国外所以这一步安装速度会很慢。

    npm install

    不要从国内镜像cnpm安装(会导致后面缺了很多依赖库)

    cnpm install

    安装 vue 路由模块vue-router和网络请求模块vue-resource

    cnpm install vue-router vue-resource --save

    启动项目

    npm run dev

    填坑(以下坑可能由于 vue2.0 导致其他相关编译打包工具没更新导致的)

    【重点】后来发现这些坑是由于 npm 不是最新的版本3.10.2, 用 npm 3.9.5就会出现以下坑
    解决办法: 请运行以下命令
    npm update -g

    报错

    Error: Cannot find module 'opn'
    Error: Cannot find module 'webpack-dev-middleware'
    Error: Cannot find module 'express'
    Error: Cannot find module 'compression'
    Error: Cannot find module 'sockjs'
    Error: Cannot find module 'spdy'
    Error: Cannot find module 'http-proxy-middleware'
    Error: Cannot find module 'serve-index'

    如果你用的是老版本的 vue-cli 还可能报其他错误,需要更新一下 vue-cli

    npm update vue-cli

    然后可以查看一下当前全局 vue-cli 的版本

    npm view vue-cli

    安装一下这个依赖到工程开发环境

    cnpm install opn --save-dev
    cnpm install webpack-dev-middleware --save-dev
    cnpm install express --save-dev
    cnpm install compression --save-dev
    cnpm install sockjs --save-dev
    cnpm install spdy --save-dev
    cnpm install http-proxy-middleware --save-dev
    cnpm install serve-index --save-dev
    cnpm install connect-history-api-fallback --save-dev

    再启动项目,报错

    ERROR in ./src/main.js
    Module build failed: Error: Cannot find module 'babel-runtime/helpers/typeof'
    at Function.Module._resolveFilename (module.js:440:15)
    at Function.Module._load (module.js:388:25)
    at Module.require (module.js:468:17)
    at require (internal/module.js:20:19)
    at Object.<anonymous> (/Volumes/MacStorage/Coding/Web/vue-test/node_modules/.6.17.0@babel-core/lib/transformation/file/index.js:6:16)
    at Module._compile (module.js:541:32)
    at Object.Module._extensions..js (module.js:550:10)
    at Module.load (module.js:458:32)
    at tryModuleLoad (module.js:417:12)
    at Function.Module._load (module.js:409:3)
    @ multi main
    ERROR in ./~/.2.1.0-beta.8@webpack-dev-server/client/socket.js
    Module not found: Error: Can't resolve 'sockjs-client' in '/Volumes/MacStorage/Coding/Web/vue-test/node_modules/.2.1.0-beta.8@webpack-dev-server/client'
    @ ./~/.2.1.0-beta.8@webpack-dev-server/client/socket.js 1:13-37
    @ ./~/.2.1.0-beta.8@webpack-dev-server/client?http://localhost:8080
    @ multi main

    安装一下 babel-runtime

    cnpm install babel-helpers --save-dev

    启动项目,再次报错

    Module build failed: Error: Cannot find module 'babel-helpers'
    Module build failed: Error: Cannot find module 'babel-traverse'
    Module build failed: Error: Cannot find module 'json5'
    Module build failed: Error: Cannot find module 'babel-generator'
    Module build failed: Error: Cannot find module 'detect-indent'
    Module build failed: Error: Cannot find module 'jsesc'

    找不到依赖那就再安装一下

    cnpm install babel-helpers --save-dev
    cnpm install babel-traverse --save-dev
    cnpm install json5 --save-dev
    ...不写了,请把全部把旧的环境全部清除,更新到最新版本

    解决办法概述

    遇到

    Module build failed: Error: Cannot find module '模块名'

    那就安装

    cnpm install 模块名 --save-dev(关于环境的,表现为npm run dev 启动不了)
    cnpm install 模块名 --save(关于项目的,比如main.js,表现为npm run dev 成功之后控制台报错)
    比如escape-string-regexp、strip-ansi、has-ansi、is-finite、emojis-list

    终于可以启动项目了

    输入完命令会自动启动浏览器,如果默认打开 IE 不行

    npm run dev

    自动启动浏览器就会看到这 帅帅的界面了。


    开始 Vue 之旅

    打开 IDE

    推荐 Atom 打开项目,需要安装 Vue 语法高亮的插件


    使用官网文档学习基础

    我们来看官网的一个例子,(中文文档请自行上网搜索)

    打开 工程目录下的 App.vue
    template 写 html,script写 js,style写样式


    为了方便叙述,我们把官网例子写在同一个组件内
    这里有两个坑:
    第一。一个组件下只能有一个并列的 div,可以这么写,所以复制官网示例的时候只要复制 div 里面的内容就好。

    但是不能这样写:

    第二。数据要写在 return 里面而不是像文档那样子写

    错误的写法:


    这样子可以自己啃完官网文档组件之前的部分了。


    来玩玩组件

    前面讲得基本上都是各种常用组件的数据绑定,下面还得说说的是 Vue 的组件的使用。
    在工程目录/src下创建component文件夹,并在component文件夹下创建一个 firstcomponent.vue并写仿照 App.vue 的格式和前面学到的知识写一个组件。

    <template>
      <div id="firstcomponent">
        <h1>I am a title.</h1>
        <a> written by {{ author }} </a>
      </div>
    </template>
    
    <script type="text/javascript">
    export default {
      data () {
        return {
          author: "微信公众号 jinkey-love"
        }
      }
    }
    </script>
    
    <style>
    </style>
    

    duang... 不能按官网文档那样子叫我做就做,我得先试试再告诉你,我做完效果是这样子的,希望观众做完也是这样子。(迷之微笑 )


    然后在 App.vue 使用组件 ( 因为在 index.html 里面定义了<div id="app"></div>所以就以这个组件作为主入口,方便 )
    第一步,引入。在<script></script>标签内的第一行写

    import firstcomponent from './component/firstcomponent.vue'
    

    第二步,注册。在<script></script>标签内的 data 代码块后面加上 components: { firstcomponent }。记得中间加英文逗号!!!

    export default {
      data () {
        return {
          msg: 'Hello Vue!'
        }
      },
      components: { firstcomponent }
    }
    

    第三步,使用
    <template></template>内加上<firstcomponent></firstcomponent>

    <template>
      <div id="app">
        ![](./assets/logo.png)
        <h1>{{ msg }}</h1>
        <firstcomponent></firstcomponent>
      </div>
    </template>
    

    完成后的代码:


    这时候看看浏览器上的 http://localhost:8080/ 页面(之前打开过就会自动刷新),如果你没看到效果是因为你没有对 App.vuefirstcomponent.vue 进行保存操作,保存后页面会自动刷新。

    使用路由搭建单页应用

    之前已经通过命令安装了vue-router

    cnpm install vue-router --save

    webpack.config.js加入别名

    resolve: {
        alias: {vue: 'vue/dist/vue.js'}
      }
    

    为什么要加 alias 配置项?其作用可以在文档中有相应的描述:


    修改完之后的webpack.config.js是这样子的:

    var path = require('path')
    var webpack = require('webpack')
    
    module.exports = {
      entry: './src/main.js',
      output: {
        path: path.resolve(__dirname, './dist'),
        publicPath: '/dist/',
        filename: 'build.js'
      },
      resolveLoader: {
        root: path.join(__dirname, 'node_modules'),
      },
      module: {
        loaders: [
          {
            test: /\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\.vue$/,
            loader: 'vue'
          },
          {
            test: /\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\.js$/,
            loader: 'babel',
            exclude: /node_modules/
          },
          {
            test: /\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\.(png|jpg|gif|svg)$/,
            loader: 'file',
            query: {
              name: '[name].[ext]?[hash]'
            }
          }
        ]
      },
      resolve: {
        alias: {vue: 'vue/dist/vue.js'}
      },
      devServer: {
        historyApiFallback: true,
        noInfo: true
      },
      devtool: '#eval-source-map'
    }
    
    if (process.env.NODE_ENV === 'production') {
      module.exports.devtool = '#source-map'
      // http://vue-loader.vuejs.org/en/workflow/production.html
      module.exports.plugins = (module.exports.plugins || []).concat([
        new webpack.DefinePlugin({
          'process.env': {
            NODE_ENV: '"production"'
          }
        }),
        new webpack.optimize.UglifyJsPlugin({
          compress: {
            warnings: false
          }
        })
      ])
    }
    

    再按之前的方法写一个组件 secondcomponent.vue

    <template>
      <div id="secondcomponent">
        <h1>I am another page</h1>
        <a> written by {{ author }} </a>
        <p> 感谢 <a href="https://github.com/showonne">showonne</a>大神的技术指导</p>
      </div>
    </template>
    
    <script>
    export default {
      data() {
        return {
          author: "微信公众号 jinkey-love",
          articles: [],
        }
      }
      }
    }
    </script>
    
    <style>
    </style>
    

    这时候修改 main.js,引入并注册 vue-router

    import VueRouter from "vue-router";
    Vue.use(VueRouter);
    

    并且配置路由规则和 app 启动配置项加上 router,旧版的 router.map 方法在 vue-router 2.0 已经不能用了。修改后的main.js如下:

    import Vue from 'vue'
    import App from './App.vue'
    import VueRouter from "vue-router";
    import VueResource from 'vue-resource'
    
    //开启debug模式
    Vue.config.debug = true;
    
    Vue.use(VueRouter);
    Vue.use(VueResource);
    
    // 定义组件, 也可以像教程之前教的方法从别的文件引入
    const First = { template: '<div><h2>我是第 1 个子页面</h2></div>' }
    import secondcomponent from './component/secondcomponent.vue'
    
    // 创建一个路由器实例
    // 并且配置路由规则
    const router = new VueRouter({
      mode: 'history',
      base: __dirname,
      routes: [
        {
          path: '/first',
          component: First
        },
        {
          path: '/second',
          component: secondcomponent
        }
      ]
    })
    
    // 现在我们可以启动应用了!
    // 路由器会创建一个 App 实例,并且挂载到选择符 #app 匹配的元素上。
    const app = new Vue({
      router: router,
      render: h => h(App)
    }).$mount('#app')
    

    这样子改完再打开浏览器看看。


    点击那两个链接试试,会发现<router-view class="view"></router-view>的内容已经展示出来,同时注意浏览器地址已经变更

    另外,也可以把 App.vue 的内容写在 main.js 也是可以的不过不建议这么做


    如果你使用 vue1.0和0.7版本的 vue-router,请参照下面这个教程, 他整个系列都不错的,当然仅限于 vue1.0 :

    http://guowenfh.github.io/2016/03/28/vue-webpack-06-router/

    给页面加点动态数据

    这时候的页面都是静态的(数据在写程序的时候已经固定了不能修改),而每个应用基本上都会请求外部数据以动态改变页面内容。对应有一个库叫 vue-resource 帮我们解决这个问题。
    使用命令行安装

    cnpm install vue-resource --save

    在 main.js 引入并注册 vue-resource:

    import VueResource from 'vue-resource'
    Vue.use(VueResource);
    

    我们在 secondcomponent.vue 上来动态加载数据
    添加一个列表:

    <ul>
          <li v-for="article in articles">
            {{article.title}}
          </li>
        </ul>
    

    在 data 里面加入数组 articles 并赋值为[]
    然后在 data 后面加入加入钩子函数 mounted(详细请参照官方文档关于 vue 生命周期的解析),data 和 mount 中间记得记得加逗号

    mounted: function() {
        this.$http.jsonp('https://api.douban.com/v2/movie/top250?count=10', {}, {
            headers: {
    
            },
            emulateJSON: true
        }).then(function(response) {
          // 这里是处理正确的回调
    
            this.articles = response.data.subjects
            // this.articles = response.data["subjects"] 也可以
    
        }, function(response) {
            // 这里是处理错误的回调
            console.log(response)
        });
      }
    

    这里使用的是豆瓣的公开 GET 接口,如果接口是跨域的 POST 请求,则需要在服务器端配置:

    Access-Control-Allow-Origin: *

    这时候运行看看。等一会接口返回数据,咦,数据加载出来了,棒棒哒 !


    更多 vue-router 的使用方法可以看

    vue-router 0.7
    http://m.doc00.com/doc/1001004eg
    vue-router 2.0
    http://router.vuejs.org/zh-cn/index.html

    来拯救如此难看的界面

    组件、双向绑定、路由、数据请求等基本特性都能用了,写到这里一个单页应用基本上成型了。但是,这几面也太 TM 难看了吧。自己写 UI 框架太费劲?那就上网找一个吧。
    本来想给大家介绍 Vux 的,因为他用的是微信的 WeUI 设计规范,对于开发微信小程序或者微信内的网页非常和谐,但由于写这篇文章的时候 Vux 还不支持 vue2.0,只能用别的框架了。
    命令行安装 ElementUI (此处某公司的人应该发红包了...)

    cnpm install element-ui@next -S

    然后在 main.js 引入并注册

    import Element from 'element-ui'
    import 'element-ui/lib/theme-default/index.css'
    Vue.use(Element)
    

    保存,这时候程序报错

    Uncaught Error: Module parse failed: /Users/**/Desktop/vue2/node_modules/.1.0.0-rc.5@element-ui/lib/theme-default/index.css Unexpected character '@' (1:0)
    You may need an appropriate loader to handle this file type.

    官网文档又有坑了,安装教程也不跟我们说这一步,当我们都是高手了...
    报错是由于我们引入了index.css这个 CSS 文件,但是 webpack 打包的时候无法识别并转换成 js,所以就需要配置才能读取 css 和字体文件,运行命令安装下面三个东西(如果之前安装过就不需要了)

    cnpm install style-loader --save-dev
    cnpm install css-loader --save-dev
    cnpm install file-loader --save-dev

    webpack.config.js 中的 loaders 数组加入以下配置,记得该加逗号的地方加逗号!

    {
        test: /\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\.css$/,
        loader: "style!css"
    },
    {
        test: /\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\.(eot|woff|woff2|ttf)([\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\?]?.*)$/,
        loader: "file"
    }
    

    修改完的 webpack.config.js 如下

    var path = require('path')
    var webpack = require('webpack')
    
    module.exports = {
      entry: './src/main.js',
      output: {
        path: path.resolve(__dirname, './dist'),
        publicPath: '/dist/',
        filename: 'build.js'
      },
      resolveLoader: {
        root: path.join(__dirname, 'node_modules'),
      },
      module: {
        loaders: [
          {
            test: /\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\.vue$/,
            loader: 'vue'
          },
          {
            test: /\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\.js$/,
            loader: 'babel',
            exclude: /node_modules/
          },
          {
              test: /\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\.css$/,
              loader: "style!css"
          },
          {
            test: /\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\.(eot|woff|woff2|ttf)([\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\?]?.*)$/,
            loader: "file"
          },
          {
            test: /\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\.(png|jpg|gif|svg)$/,
            loader: 'file',
            query: {
              name: '[name].[ext]?[hash]'
            }
          }
        ]
      },
      resolve: {
        alias: {vue: 'vue/dist/vue.js'}
      },
      devServer: {
        historyApiFallback: true,
        noInfo: true
      },
      devtool: '#eval-source-map'
    }
    
    if (process.env.NODE_ENV === 'production') {
      module.exports.devtool = '#source-map'
      // http://vue-loader.vuejs.org/en/workflow/production.html
      module.exports.plugins = (module.exports.plugins || []).concat([
        new webpack.DefinePlugin({
          'process.env': {
            NODE_ENV: '"production"'
          }
        }),
        new webpack.optimize.UglifyJsPlugin({
          compress: {
            warnings: false
          }
        })
      ])
    }
    

    给豆瓣的电影列表套个衣服(样式) :

    <el-card class="box-card">
          <div slot="header" class="clearfix">
            <h1 style="line-height: 36px; color: #20A0FF">豆瓣电影排行榜</h2>
          </div>
          <div v-for="article in articles" class="text item">
            {{article.title}}
          </div>
    </el-card>
    

    打开浏览器,输入网址:

    http://localhost:8080/second


    列表比之前漂亮多了,你还可以参照 ElementUI 的文档使用更多组件样式

    http://element.eleme.io/#/component/layout

    编译

    npm run build

    又报错了...orz

    ERROR in build.js from UglifyJs
    SyntaxError: Unexpected token punc «(», expected punc «:» [build.js:32001,6]

    解决办法(21061019 showonne 提交 PR 已合并到主分支)

    cnpm install babel-preset-es2015 --save-dev
    cnpm install babel-preset-stage-0 --save-dev

    然后在项目目录下创建一个.babelrc文件,内容如下:

    {
        presets: ['es2015', 'stage-0']
     }
    

    或者在webpack.config.js中这里

    {
            test: /\\\\.js$/,
            loader: 'babel',
            exclude: /node_modules/
          }
    

    加入 presets 配置,修改成下面酱紫:

    {
            test: /\\\\.js$/,
            loader: 'babel',
            exclude: /node_modules/,
            query: {presets: ['es2015', 'stage-0']
          }
    

    再次执行 npm run build 就可以了,后来发现直接运行 webpack 命令也是可以打包的

    webpack --color --progress

    接着把 index.html 和整个 dist 目录丢到服务器就可以了。

    如果你觉得这篇文章写得好,不需要打赏,你可以下载我朋友做的一个阅读工具,可以订阅公众号和简书、也可以看大神分享的优秀文章。
    下载地址:https://itunes.apple.com/us/app/you-duuread-zhi-gei-xiang/id1175225244

    App Store 截图

    相关文章

      网友评论

      • York1987:這是個坑!!!!!!!!不要跟著做, 好多漏掉的
        JinkeyAI:@York1987 请看清楚这是什么时候什么版本的教程,谢谢
        York1987:小白慎入
      • 08220c952305:谢博主拯救:pray:
      • 60a9b30aaeda:"接着把 index.html 和整个 dist 目录丢到服务器就可以了。"这里有个问题,只能把它丢到服务器根目录,其他子页面不可以。因为webpack默认配置是绝对路径。webpack模版可以在config/index.js设置改变,可是webpack-simple的模版配置相对路径应该在哪里修改?
      • aguai0:照着做了一遍,很多都不懂
        5d9a66c11402:现在的vue2.0和这个文档有些地方是有出入的 找新的文档看吧
      • 朱朱朱朱朱W:谢谢,小白看了觉得很清晰易懂
      • 4b74e6055137:按照这里所讲的运行成功了,关闭之后在次启动 npm run dev 时报错,怎么回事
      • 苏敏:data () {
        return {
        msg: 'Welcome to Your Vue.js App'
        }
        }
        这种写法等效于:
        data :function () {
        return {
        msg: 'Welcome to Your Vue.js App'
        }
        }
        文章写得太啰嗦
      • kakakkk:楼主,如何拼接 接口url参数呀。
      • IT晴天:建议博主再整理下,内容有冗余,而且至少有三个错误,和几处不规范的,会误导初学者,不过内容算全面也值得赞
        JinkeyAI:@IT_晴天 vue2.0 刚出的时候这个代码是完全没问题的,但是现在很多依赖都升级了,另外我现在很少写网页了,仓库已交给朋友管理。
      • overla5:你好,为什么我先点完第一页的链接,点第二页,再回来点第一页就没反应了
      • 今天_73f3:现在好像都用axios来做获取数据的插件了吧
      • 山门龙龙:哈哈,我是第520个点赞的人,楼主,我们在一起吧?:heart_eyes:
      • 进击柚子:中间重复太多了,请删掉一半吧,不然影响阅读,谢谢了
        扬沙沙: @兜兜转转101 支持啊,原文不需要复制两遍吧
      • d4d3b3a1a5a7:可以告诉我怎么从2.0安装回1.0吗:sob::sob::sob:
      • 85a5da6d9e1c:最后找到是安装的问题换成这样命令安装就没问题了cnpm install element-ui -S
      • ba5a27befac5:坑,代码不给全!
      • ba5a27befac5:楼主啊,你这个例子的代码是不是没有完整展示出来啊,<router-view>这个标签我怎么发现不了?
      • 8d221e7fbf7e:您好,我能加一下您的微信号嘛?我是gitchat的策划。想邀请您来我们gitchat做一次技术分享 。
      • 85a5da6d9e1c:
        我只能说群猪这个坑也大最后那个引用css我磨了几天才去掉各种坑

        第一个坑:
        webpack报错:
        resolveLoader: {
        root: path.join(__dirname, 'node_modules'),
        },这个删除停止报错!!
        secondcomponent.vue文件里面的
        <el-card class="box-card">
        <div slot="header" class="clearfix">
        <h1 style="line-height: 36px; color: #20A0FF">豆瓣电影排行榜</h1>
        </div>
        <div v-for="article in articles" class="text item">
        {{article.title}}
        </div>
        </el-card>
        俩处报错
        重点是《el-card》改成div
        <h1></h2>
        这标题结束应该是</h1>
        85a5da6d9e1c:<h1 style="line-height: 36px; color: #20A0FF">豆瓣电影排行榜</h1>是我改掉的群猪可以看下你文档还是文章结束都是</h2>
      • index_ab68:安装淘宝镜像 一直报错 怎么办?
      • du1wu2lzlz:写的很详细 基本上刚接触时遇到的问题都有所说明 赞!
      • b33f3c708c7c:你好,在webpack.config.js如何加入别名呀,
      • ErHu丶:mac 的 atom好卡 这是为什么呢
      • 易冷zzz:在搭建单页面的地方没有看到在哪里有写<router-view class="view"></router-view>,后面就直接列出结果了,是不是跨越有点大了,这点不太理解,跟着你的节奏走到这断了,一直报错vue is not defined 请问是什么问题
      • 水哥一点也不水:多谢楼主分享,找了好久终于解决了!
      • Y了个J:大牛,为什么我安装了 stylus-loader 后,<style lang="stylus" rel="stylesheet/stylus"></style> 这个里面写样式, npm run dev 后报错 Module build failed: Error: Cannot find module 'stylus' ,你知道什么原因吗
      • af788bd44213:发现你上面有个坑!!!!就是引入vue-router之后,你上面说要在webpack.config.js加上resolve: {
        alias: {vue: 'vue/dist/vue.js'}
        },我这样子做了一直在报错,后来删了这个就ok了可以正常运行了!!你说坑不吭??
        43c431ed2b1f:看你怎么安装的喽。如果是‘运行时 + 编译器’,就不需要加这行代码,如果是‘runtime’,就需要这行代码。凭心而论,这篇博客写的还是很棒的
      • QuietMing:还没看完。先谢谢:+1:
      • 我是小栗子:感谢楼主的分享,有一点想问下,为什么我的列表没出来
        就是那两个点击跳转到第几页
        我是小栗子:我服务器抽抽了:sweat:
      • 孤独的探索号:教程很好,已经跑起来了:+1:
      • 无语听梧桐:要是一直出现 cannot find module '模块名'有什么简单的解决办法么
      • 无语听梧桐:前辈 为什么我按照你的教程 在路由那一块 一直提示duplicate declaration “router”
      • 追逐cc:vue-cli如何引入外部的插件,如swiper,jquery
      • SunnySky_:请问如何在android里面调取vue的方法呢?
        JinkeyAI:@iceuncle 没写安卓
      • kahn17:很有收获谢谢!再 问问webpack.config.js是哪个?我的build里面有base dev prod三个配置文件呀
      • harmsworth2017:博主,请参考这篇文章,很简洁的http://leenty.com/2016/10/21/vue2-1/
        harmsworth2017:虽然在安装依赖时写错了,应该是npm install
      • Yasin的简书:楼主你忘了写app里面link的代码了,我看了好久才发现的:sweat:
      • 18fc3077f12b:赞赞赞,百度搜了如何部署结果一大堆没用的,都不如你一句 “接着把 index.html 和整个 dist 目录丢到服务器就可以了”,问题解决了。:smile:
        JinkeyAI: @Switch_3cfd 百度搜索越来越废
      • 796f73614807:发布成app是用的cordova吗。
        796f73614807:@JinkeyBlog 首先我将vue 的run build了 然后我把src文件丢到cordava的www下替换掉 然后run android app打开就是空白...
        796f73614807:@JinkeyBlog 有联系方式吗 想问个问题.
        JinkeyAI: @Gemini哟 weex
      • AAAAA汪洋:总的来说还行,但是对于小白来说 有两个点没有说明白,比较水.比如获取数据的代码写在那个文件? 两个a链接写在那个页面?都没有说.小白容易懵逼.
      • 57b5f74426aa:入坑必备
      • f404811519e1:./src/router/index.js
        Module not found: Error: Can't resolve '@/components/fisrtcomponent' in '/Users/apple/Desktop/my-project/src/router'
        不知道 这个 index.js 里的router 咋写 :sweat:
      • 巴黎夜雨_5fd9:App.vue和firstcompoent.vue都保存了,但是在localhost中打开还是App.vue这个页。如何运行firstcompoent.vue
      • 0111035bda19:作者 在吗 我想问一下 我做了几次做到 “<div><h2>我是第 1 个子页面</h2></div>” 这里 下面都不会显示连接 我的是window系统 请问是这个原因吗 我看配置文件有些也和你不一样 请问是系统问题吗
      • Sun_196e:“ 接着把 index.html 和整个 dist 目录丢到服务器就可以了 ”
        为什么我这样打开的index.html是一片空白
      • 71f0b7b628ac:非常感谢
      • 38c49360dc70:提示vue指令找不到?怎么破?
      • 小小游轮:学习了
      • 0b900edf97d1:cnpm run build还是报错
      • 另一种灿烂生活09:npm run dev 时候npm ERR怎么办啊。
      • zshanjun:中间重复了
      • 578d890348d0:打包后将dist文件夹和index.html丢到站点中页面显示空白,not fond dist.js。将index.heml中的script内容(/dist/dist.js)改为(dist/dist.js)后图片有出不来了。这个是什么问题呀
      • fangtang0101:ERROR in build.js from UglifyJs
        SyntaxError: Unexpected token punc «(», expected punc «:» [build.js:23154,16]
        请问 博主 ,最后这个 具体是 怎么解决的,因为我也是遇到这个问题,万分感谢,您这边 说的太笼统了
      • 4370f21231fb:改解决的解决了 build.js 也生成了, 但是页面还是出不来 index.html:9 GET file:///C:/dist/build.js net::ERR_FILE_NOT_FOUND
        4370f21231fb:@风云酷小子 尴尬就是服务器中运行不了,就尝试双击运行,然后出现的这个。。。暂时弃疗了,弄了五六个小时还是卡在那里,,重新安装了6,7遍 还是那样= =
        风云酷小子:@4370f21231fb 谁叫你们双击index.html运行的???放服务器中,用http协议才能访问
        df2efed89253::sweat: 我也是
      • 4370f21231fb:....一直卡在 ERROR in Entry module not found: Error: Can't resolve 'babel-loader' in 'C:\Users\tianjie.yang\Documents\GitHub\vueDemo\yozoVueApp' ,,,重新装了几次babel-loader还是不行
        巴黎夜雨_5fd9:我也有这个问题,你解决了么
      • 6ed30913770a:写的挺详细的 新手福音:smile:
      • 8de24bd5e07f:跑不起来 提示VueResource有错
      • 望星star:dalao,引UI框架那段用npm install element-ui@next -S下载的包是1.0.0-rc-9,这个包不知为何页面执行会报错,需要改成1.0.0或其他版本才不会报错。
      • RobertCrazying:有个bug,就是点了第一页或第二页刷新页面显示404了
        RobertCrazying:@JinkeyBlog 但是你那live demo也有这bug啊
        JinkeyAI:@RobertCrazying 因为这是相对路径,你得先打包,不能直接打开
      • d9fda9baa7b8:[Vue warn]: Cannot find element: #app 楼主 一直报这个 所以卡在这里 学不下去啦

        你有qq吗 我觉得你的教程是我刚学vue的最好的 我想和你交流一下 希望可以 谢谢了

        38f05b1582ea:这个提示是 你的页面上找不到id为app的元素,你没有设置id="app":cold_sweat:
      • 九号咖啡屋:搞不懂你前面安装 brew 和 淘宝 是干嘛用的
        JinkeyAI:@_九叔 Mac的软件管理工具
      • 194181740bd6:0 info it worked if it ends with ok
        1 verbose cli [ 'C:\\Program Files\\nodejs\\node.exe',
        1 verbose cli 'C:\\Program Files\\nodejs\\node_modules\\npm\\bin\\npm-cli.js',
        1 verbose cli 'run',
        1 verbose cli 'dev' ]
        2 info using npm@3.10.9
        3 info using node@v6.9.2
        4 verbose run-script [ 'predev', 'dev', 'postdev' ]
        5 info lifecycle vue2@~predev: vue2@
        6 silly lifecycle vue2@~predev: no script for predev, continuing
        7 info lifecycle vue2@~dev: vue2@
        8 verbose lifecycle vue2@~dev: unsafe-perm in lifecycle true
        9 verbose lifecycle vue2@~dev: PATH: C:\Program Files\nodejs\node_modules\npm\bin\node-gyp-bin;D:\vue2-example-master2\vue2-example-master\node_modules\.bin;C:\Users\qw\bin;C:\Program Files (x86)\Git\mingw32\bin;C:\Program Files (x86)\Git\usr\local\bin;C:\Program Files (x86)\Git\usr\bin;C:\Program Files (x86)\Git\usr\bin;C:\Program Files (x86)\Git\mingw32\bin;C:\Program Files (x86)\Git\usr\bin;C:\Users\qw\bin;C:\Program Files (x86)\Common Files\NetSarang;C:\Program Files (x86)\Intel\iCLS Client;C:\Program Files\Intel\iCLS
      • 598440fb07f6:运行报错了。。。
        0 info it worked if it ends with ok
        1 verbose cli [ 'D:\\nodejs\\node.exe',
        1 verbose cli 'D:\\nodejs\\node_modules\\npm\\bin\\npm-cli.js',
        1 verbose cli 'run',
        1 verbose cli 'dev' ]
        2 info using npm@3.8.9
        3 info using node@v6.2.0
        4 verbose run-script [ 'predev', 'dev', 'postdev' ]
        5 info lifecycle test@1.0.0~predev: test@1.0.0
        6 silly lifecycle test@1.0.0~predev: no script for predev, continuing
        7 info lifecycle test@1.0.0~dev: test@1.0.0
        8 verbose lifecycle test@1.0.0~dev: unsafe-perm in lifecycle true
        9 verbose lifecycle test@1.0.0~dev: PATH: D:\nodejs\node_modules\npm\bin\node-gyp-bin;F:\study\vue\node_modules\.bin;D:\nodejs;C:\Windows\system32;C:\Windows;C:\Windows\System32\Wbem;C:\Windows\System32\WindowsPowerShell\v1.0\;F:\software\jdk1.7.0_67_X64\bin;C:\Program Files\TortoiseSVN\bin;F:\software\apache-maven-3.2.5\bin;D:\nodejs\;D:\less.js-windows-master;F:\software\jdk1.7.0_67_X64\jre;C:\Users\Administrator\AppData\Roaming\npm
        10 verbose lifecycle test@1.0.0~dev: CWD: F:\study\vue
        11 silly lifecycle test@1.0.0~dev: Args: [ '/d /s /c',
        11 silly lifecycle 'cross-env NODE_ENV=development webpack-dev-server --open --inline --hot' ]
        12 silly lifecycle test@1.0.0~dev: Returned: code: 1 signal: null
        13 info lifecycle test@1.0.0~dev: Failed to exec dev script
        14 verbose stack Error: test@1.0.0 dev: `cross-env NODE_ENV=development webpack-dev-server --open --inline --hot`
        14 verbose stack Exit status 1
        14 verbose stack at EventEmitter.<anonymous> (D:\nodejs\node_modules\npm\lib\utils\lifecycle.js:245:16)
        14 verbose stack at emitTwo (events.js:106:13)
        14 verbose stack at EventEmitter.emit (events.js:191:7)
        14 verbose stack at ChildProcess.<anonymous> (D:\nodejs\node_modules\npm\lib\utils\spawn.js:24:14)
        14 verbose stack at emitTwo (events.js:106:13)
        14 verbose stack at ChildProcess.emit (events.js:191:7)
        14 verbose stack at maybeClose (internal/child_process.js:850:16)
        14 verbose stack at Pr
        194181740bd6:@598440fb07f6 我也是这个问题。层主解决了没
      • 110117d9c8c9:为毛照着上面操作的我没有node_moduls这个文件夹
        巴黎夜雨_5fd9:npm install或者cnpm install 一下就有了
      • b3c7052248a0:你好厉害啊!感觉还是女生
      • 柏渡人:打包出来的东西本地运行一闪就没有了 哪位大神指教
      • 0556e734b513:之前用vue2.0做了个简单的音乐播放器,有兴趣可以交流下
        https://github.com/heiliuer/vue-study/tree/master/007vue-webpack-music
      • 0556e734b513:上个月也走过了webpack+vue2.0的流程,也遇到好些问题。最后总结是,大部分问题都可以仔细阅读最新的vue文档解决
      • Felix666:楼主,我用vue init webpack-simple <name>生成的项目总是报找不到样式,用vue init webpack <name>生成的项目就不会,这是为什么
      • d93c5780ee3e:那个webpack.config.js在哪个目录里呢?build吗
        JinkeyAI:@this_css 看github的目录
      • _隔壁老王:正在npm update -g。。。 这几天刚进坑。搜楼的基本全是1.0的教程。突然碰到2.0的此贴,目测是可以少兜几条弯路呀~~~
        JinkeyAI:@_隔壁老王 哈哈,打到微信嘛,简书很难提现的
        _隔壁老王:花了一整个下午在公司code了一下,受益匪浅,果断打赏了楼主以表小敬hahah
      • 45320bbf715c:“不要从国内镜像cnpm安装(会导致后面缺了很多依赖库)”这个你遇见过这种问题?cnpm现在不是10分钟更新一次,与npm库保持一致的吗
        JinkeyAI:@奇遇部 理论上是没问题的,但不知道为什么会异常
      • 0bc29418e984:多谢作者,非常好的入门教程
      • 7bd539b44a5c:楼主写的太好了!谢谢分享。想问下楼主你源码里面的vue的语法不完全是2.0的写法呀?
      • 94058a2020e6:博主非常感谢你的教程 我想请教一下 你的demo 是通过什么方法生成的
        JinkeyAI:@reset69 按教程里面说的方法生成的吖
        94058a2020e6:@JinkeyBlog 额 谢谢 博主能不能具体一点 :cry:
        JinkeyAI:vue-cli
      • 旗木写轮眼卡卡西:不错哈。我照着你的方法搞了一下,发现有报错。
      • 3800e1d13c47:新手,Element UI按照上面说的index.css还是报那个错
        3800e1d13c47:@dark啡 再次重新启动命令行都错的,启动不了
        3800e1d13c47:启动过了还是2个固定的错误
        7e2f6f85a495:@3800e1d13c47 开始我也报错,后来重新热启动了一下可以了
      • 96f25b8383cc:6666666ios 也开始学前端了么
      • 郭鵬飛on:Failure: 403 Forbidden 这个怎么解决
      • 343762af0373:找这个文章找哭了! :unamused:
        JinkeyAI:@mahonlee 为什么要找,文章一直都在:flushed:
      • 明天的天明:终于帮我把坑填了,谢谢咯 :smile:
      • bb8d724cc20b:希望楼主发一份demo,707131016@qq.com,就是上面这个例子即可,非常感谢
        JinkeyAI:@七步云 github上面的代码和文章的是一样的吖
      • bb8d724cc20b:求demo ,对着比发的东西打代码,不全,感谢啊 707131016@qq.com :relieved: 很想学vue
      • BosenY:写的好棒,对于我这种小白来说简直救命!!!
      • 虾哔哔:不好意思,想问一下,就是用npm run build 命令构建出来的dist文件夹里面的index.html文件可以直接在本地环境下浏览吗,我构建完之后发现index.html里面和初始index.html一样,只是加了几个js文件,但是本地浏览看不到内容,是需要在服务器下浏览吗,还是说我这个构建是有问题的
        JinkeyAI:@Mrcxt npm run build其实就是本地启动了一个服务器,不能直接打开index.html的,因为读取的是根目录,必须服务器打开才能读取到引用的文件。
      • xunuo0x:首先表示感谢感谢!学习啦 :smile: ~然后有个简单的问题哈,clone了你的代码之后,怎么在本地跑起来呢?
        xunuo0x:@JinkeyBlog 明白~谢谢
        JinkeyAI:@xunuo0x 进入工程目录,npm install安装依赖之后npm run dev即可
      • 2ac5cd38effc:楼主 我路由老是配置不起来是怎么回事呀?也不会报错。始终是firstcomponent的界面。
        493dcded4107:@JinkeyBlog 我也是 没跑起来。。在 加入router那一节里面。。跑起来的项目还是firstcomponent呢 T T
        2e0ece536b3d:@PassionJessie @JinkeyBlog 因为文章作者在 “使用路由搭建单页应用” 这节中,遗漏了怎么改写 App.vue 的内容,希望作者能补充完整
        JinkeyAI:@PassionJessie 你clone一下我github的代码能跑吗
      • a8afff42901a:补个坑 Mac 10.11 brew安装最新的 nodejs + npm + blabla, 可以打包成功。
        微播鹿:@a8afff42901a 最好不用brew 我改nvm 切换node了现在
      • a8afff42901a:thx a lot!!!, it's really help a lot!!
        JinkeyAI:@a8afff42901a 期待你的教程
        a8afff42901a:@JinkeyBlog 找了2天没找到合适的vue 2.0大礼包+webpack 的入门文档,你这个比较对口味,呵呵。

        看完你的文档以后,今天补了 vuex,明后天就准备开始写第一个demo了。
        JinkeyAI:@a8afff42901a 看来你英语不错可以直接啃英文文档哟
      • cbw100:不错,赞赞
      • 深海泰坦:其实你这个前面的报错都是个人的,大多数人根本用不到。
        深海泰坦:@194181740bd6 怎么了
        194181740bd6:@深海泰坦 在不在
        JinkeyAI:@深海泰坦 因为你从0开始安装环境,对于之前配置了1.0环境的,升级过程可能会出现这些报错
      • 2e0ece536b3d:关于界面,可以看看这个material-ui 的 vue2 实现:https://github.com/museui/muse-ui,我很喜欢
        JinkeyAI:@tom0 好的,我看看,谢谢哈
      • 巴图鲁:厉害

      本文标题:Vue2.0 新手完全填坑攻略——从环境搭建到发布

      本文链接:https://www.haomeiwen.com/subject/qfsvyttx.html