Vue入门(一)

Vue入门(一)


  在这个系列中,将通过一个案例,讲解Vue的一些概念。

  这个案例主要来源于网络上的一篇文章“vue-router基本使用”

  一、生成Vue项目

  Vue程序是由一系列组件构成的,组件的后缀名是.vue,那么它肯定不能直接发布。.vue文件要经过处理,生成.js文件才能发布。

  在Vue开发中,通常使用Webpack对Vue项目进行处理。Webpack的功能很多,可以自行百度了解。

  Webpack的配置通常比较繁琐,所以Vue提供了一个“脚手架”,叫vue-cli,帮助我们快速生成Vue项目。


  1. 安装vue-cli

  命令:npm install -g vue-cli

  2. 使用vue-cli生成Vue项目

  假设我们要把项目建在E:\vue-demo文件夹下。

  首先切换到E盘根目录并输入:


  vue init webpack vue-demo

  在生成Vue项目之前,需要收集一些信息,如项目名、作者等,有些选项需要做选择(使用上下箭头选择并回车)。




  上图中,要求我们选择“Vue build”,我们可以选择第一项并回车。

  如下图所示选择其它选项并生成Vue项目:




  这里之所以不选择使用ESLint,是因为初学者可能会不习惯这个功能。ESLint用于检查JS语法,不符合它规范的语法,会报错并且导致Vue程序无法运行。

  Vue项目生成后,使用“npm run dev”即可运行。

  “npm run dev”命令执行时,会打开一个内置的Web服务器“webpack-dev-server”,在浏览器的地址栏中输入:“http://localhost:8080/”,可以看到运行结果。


  二、Vue项目的目录结构

  在Visual Studio Code中,打开E:\vue-demo文件夹,可以看到Vue项目的目录结构如下:




  我们来详细解说一下这些文件和文件夹的作用。

  1. index.html
  index.html是首页,Vue框架构建的是单页应用,整个App只有一个页面,其它功能都是“Vue组件”,放在.vue文件中。

  index.html中的内容很简单,<body>中只有一行:“<div id="app"></div>”。


  2. package.json

  这个文件是项目的配置信息。


[javascript]  view plain  copy
  1. {  
  2.   "name""vue-demo"// 项目名  
  3.   "version""1.0.0"// 版本号  
  4.   "description""A Vue.js project",  
  5.   "author""hanhf",  
  6.   "private"true,  
  7.   "scripts": { // 脚本  
  8.     "dev""webpack-dev-server --inline --progress --config build/webpack.dev.conf.js",  
  9.     "start""npm run dev"// 可以用npm start启动项目  
  10.     "build""node build/build.js"  
  11.   },  
  12.   "dependencies": { // 应用依赖项  
  13.     "vue""^2.5.2",  
  14.     "vue-router""^3.0.1"  
  15.   },  
  16.   "devDependencies": { // 编译依赖项  
  17.     "autoprefixer""^7.1.2",  
  18.     "babel-core""^6.22.1",  
  19.     "babel-helper-vue-jsx-merge-props""^2.0.3",  
  20.     "babel-loader""^7.1.1",  
  21.     "babel-plugin-syntax-jsx""^6.18.0",  
  22.     "babel-plugin-transform-runtime""^6.22.0",  
  23.     "babel-plugin-transform-vue-jsx""^3.5.0",  
  24.     "babel-preset-env""^1.3.2",  
  25.     "babel-preset-stage-2""^6.22.0",  
  26.     "chalk""^2.0.1",  
  27.     "copy-webpack-plugin""^4.0.1",  
  28.     "css-loader""^0.28.0",  
  29.     "extract-text-webpack-plugin""^3.0.0",  
  30.     "file-loader""^1.1.4",  
  31.     "friendly-errors-webpack-plugin""^1.6.1",  
  32.     "html-webpack-plugin""^2.30.1",  
  33.     "node-notifier""^5.1.2",  
  34.     "optimize-css-assets-webpack-plugin""^3.2.0",  
  35.     "ora""^1.2.0",  
  36.     "portfinder""^1.0.13",  
  37.     "postcss-import""^11.0.0",  
  38.     "postcss-loader""^2.0.8",  
  39.     "postcss-url""^7.2.1",  
  40.     "rimraf""^2.6.0",  
  41.     "semver""^5.3.0",  
  42.     "shelljs""^0.7.6",  
  43.     "uglifyjs-webpack-plugin""^1.1.1",  
  44.     "url-loader""^0.5.8",  
  45.     "vue-loader""^13.3.0",  
  46.     "vue-style-loader""^3.0.1",  
  47.     "vue-template-compiler""^2.5.2",  
  48.     "webpack""^3.6.0",  
  49.     "webpack-bundle-analyzer""^2.9.0",  
  50.     "webpack-dev-server""^2.9.1",  
  51.     "webpack-merge""^4.1.0"  
  52.   },  
  53.   "engines": {  
  54.     "node"">= 6.0.0",  
  55.     "npm"">= 3.0.0"  
  56.   },  
  57.   "browserslist": [  
  58.     "> 1%",  
  59.     "last 2 versions",  
  60.     "not ie <= 8"  
  61.   ]  
  62. }  

  3. build目录


  存放构建脚本。

  我们可以修改build目录中的webpack.base.conf.js,将ESLint语法检查取消掉,免得JS代码中总是出现错误提示:


[javascript]  view plain  copy
  1. const createLintingRule = () => ({  
  2.   // test: /\.(js|vue)$/,  
  3.   // loader: 'eslint-loader',  
  4.   // enforce: 'pre',  
  5.   // include: [resolve('src'), resolve('test')],  
  6.   // options: {  
  7.   //   formatter: require('eslint-friendly-formatter'),  
  8.   //   emitWarning: !config.dev.showEslintErrorsInOverlay  
  9.   // }  
  10. })  

  4. config目录


  存放开发环境的配置。


  我们可以修改config目录中的index.js文件,改变Web端口。


  5. dist目录

  存放打包生成的结果。这是可以发布到生产环境的结果。

  可以试着用“npm run build”构建一次,看一下dist目录中的内容有哪些。

  每次构建都会清空这个目录,重新生成。


  6. node_modules目录

  存放Node的模块,Vue项目中用到的模块都放在这个目录,方便构建时使用。

  7. src目录

  存放开发者的代码。

  8. static目录

  存放静态资源。Webpack在构建时不处理static目录中的内容。

  9. test目录

  存放测试代码。
  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值