美文网首页代码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三个配置文件呀
  • edbe76dad2b7:博主,请参考这篇文章,很简洁的http://leenty.com/2016/10/21/vue2-1/
    edbe76dad2b7:虽然在安装依赖时写错了,应该是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
  • fa565d84ee16:总的来说还行,但是对于小白来说 有两个点没有说明白,比较水.比如获取数据的代码写在那个文件? 两个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