Node.js构建Vue项目
文章目录1. 安装node.js2. 配置环境变量3. 安装项目依赖4. 启动项目1. 安装node.jsnode.js v10.16.0官网下载链接2. 配置环境变量3. 安装项目依赖在项目里打开终端terminal, 输入命令npm installnpm install 报错: chromdriver connectreset解决方法:使用npm安装谷歌驱动, 下载完成后, 将下载好的驱动拷贝
1. 安装node.js
node.js v10.16.0官网下载链接
我的安装路径为: D:\Program Files\nodejs,安装完后的Node.js长这样:
2. 配置环境变量
添加系统变量NODE_PATH,如下图:
在cmd命令行中输入: node -v 或 npm -v ,如果出现版本号,那么表示Node.js安装和配置环境变量成功了!
3. 配置node安装依赖的镜像
我们可以选择使用淘宝的镜像来配置:
npm install -g cnpm --registry=https://registry.npm.taobao.org
上述安装完后,重启电脑即可生效!
如果没有vue, 那么可以使用npm 构建vue项目
npm init vue@latest
4. 安装vue项目依赖
在项目里打开终端terminal, 输入命令:
$ npm install
安装时出现npm install 报错: chromdriver connectreset
上述问题是连接谷歌的网站出现问题,对此问题我们可以选择使用npm来安装依赖,方式如下:
解决方法
使用npm安装谷歌驱动, 下载完成后, 将下载好的驱动拷贝到指定路径里:
npm install chromedriver --chromedriver_cdnurl=http://cdn.npm.taobao.org/dist/chromedriver
将下载完毕的.zip文件拷贝到如下路径里Local目录下的文件里
C:\Users\yinfa\AppData\Local\Temp\2.46\chromedriver
拷贝完后,重新执行命令: npm install! 即可解决谷歌驱动安装不上的问题!
为了后续使用命令方便,可继续安装vue/cli
npm install -g @vue/cli
npm install -g @vue/cli-init
5. 启动vue项目
使用npm安装完依赖后,就可以把项目给run起来了, 在终端输入命令:
npm run dev
然后执行run命令报错npm: no such file or directory, scandir ‘…/node_modules/node-sass/vendor’
因为在build的时候依赖里没有node-saas模块,因此我们可以在项目的终端里输入如下命令:
npm rebuild node-sass
安装完毕后,在项目的node_models目录下就会出现该node-saas模块,如下图:
有了node-saas模块后,重新执行命令npm run dev:
访问地址: localhost:80,出现系统首页或指定页面表示项目启动成功!
6. 初始化一个新的项目
拥有了上述安装的依赖和工具后,我们可以通过Node.js里的npm打包工具将web项目运行起来了,如果需要创建一个新的项目,那么如何去创建呢?
使用webpack来init一个项目, 在指定目录输入如下命令:
vue init webpack my-project
cd D:\webWorkspace
vue init webpack my-project
cd my-project
npm run dev
完整步骤如下:
D:\webWorkspace>vue init webpack my-project
? Project name my-project
? Project description A Vue.js project
? Author
? Vue build standalone
? Install vue-router? Yes
? Use ESLint to lint your code? Yes
? Pick an ESLint preset Standard
? Set up unit tests Yes
? Pick a test runner jest
? Setup e2e tests with Nightwatch? Yes
? Should we run `npm install` for you after the project has been created? (recommended) npm
vue-cli · Generated "my-project".
# Installing project dependencies ...
# ========================
npm WARN deprecated eslint-loader@1.9.0: This loader has been deprecated. Please use eslint-webpack-plugin
npm WARN deprecated extract-text-webpack-plugin@3.0.2: Deprecated. Please use https://github.com/webpack-contrib/mini-css-extract-plugin
npm WARN deprecated browserslist@2.11.3: Browserslist 2 could fail on reading Browserslist >3.0 config used in other tools.
npm WARN deprecated core-js@2.6.12: core-js@<3 is no longer maintained and not recommended for usage due to the number of issues. Please, upgrade your dependencies to the actual version of core-js@3.
npm WARN deprecated request@2.88.2: request has been deprecated, see https://github.com/request/request/issues/3142
npm WARN deprecated bfj-node4@5.3.1: Switch to the `bfj` package for fixes and new features!
npm WARN deprecated chokidar@2.1.8: Chokidar 2 will break on node v14+. Upgrade to chokidar 3 with 15x less dependencies.
npm WARN deprecated har-validator@5.1.5: this library is no longer supported
npm WARN deprecated mkdirp@0.5.1: Legacy versions of mkdirp are no longer supported. Please update to mkdirp 1.x. (Note that the API surface has changed to use Promises in 1.x.)
npm WARN deprecated json3@3.3.2: Please use the native JSON object instead of JSON 3
npm WARN deprecated fsevents@1.2.13: fsevents 1 will break on node v14+ and could be using insecure binaries. Upgrade to fsevents 2.
npm WARN deprecated browserslist@1.7.7: Browserslist 2 could fail on reading Browserslist >3.0 config used in other tools.
npm WARN deprecated circular-json@0.3.3: CircularJSON is in maintenance only, flatted is its successor.
npm WARN deprecated socks@1.1.10: If using 2.x branch, please upgrade to at least 2.1.6 to avoid a serious bug with socket data flow and an import issue introduced in 2.1.0
npm WARN deprecated left-pad@1.3.0: use String.prototype.padStart()
npm WARN deprecated request-promise-native@1.0.9: request-promise-native has been deprecated because it extends the now deprecated request package, see https://github.com/request/request/issues/3142
npm WARN deprecated resolve-url@0.2.1: https://github.com/lydell/resolve-url#deprecated
npm WARN deprecated urix@0.1.0: Please see https://github.com/lydell/urix#deprecated
> chromedriver@2.46.0 install D:\webWorkspace\my-project\node_modules\chromedriver
> node install.js
ChromeDriver binary exists. Validating...
ChromeDriver 2.46.628402 (536cd7adbad73a3783fdc2cab92ab2ba7ec361e1)
ChromeDriver is already available at 'C:\Users\yinfa\AppData\Local\Temp\2.46\chromedriver\chromedriver.exe'.
Copying to target path D:\webWorkspace\my-project\node_modules\chromedriver\lib\chromedriver
Done. ChromeDriver binary available at D:\webWorkspace\my-project\node_modules\chromedriver\lib\chromedriver\chromedriver.exe
> core-js@2.6.12 postinstall D:\webWorkspace\my-project\node_modules\core-js
> node -e "try{require('./postinstall')}catch(e){}"
Thank you for using core-js ( https://github.com/zloirock/core-js ) for polyfilling JavaScript standard library!
The project needs your help! Please consider supporting of core-js on Open Collective or Patreon:
> https://opencollective.com/core-js
> https://www.patreon.com/zloirock
Also, the author of core-js ( https://github.com/zloirock ) is looking for a good job -)
> uglifyjs-webpack-plugin@0.4.6 postinstall D:\webWorkspace\my-project\node_modules\webpack\node_modules\uglifyjs-webpack-plugin
> node lib/post_install.js
npm notice created a lockfile as package-lock.json. You should commit this file.
npm WARN ajv-keywords@2.1.1 requires a peer of ajv@^5.0.0 but none is installed. You must install peer dependencies yourself.
npm WARN optional SKIPPING OPTIONAL DEPENDENCY: fsevents@1.2.13 (node_modules\fsevents):
npm WARN notsup SKIPPING OPTIONAL DEPENDENCY: Unsupported platform for fsevents@1.2.13: wanted {"os":"darwin","arch":"any"} (current: {"os":"win32","arch":"x64"})
npm WARN optional SKIPPING OPTIONAL DEPENDENCY: fsevents@2.3.1 (node_modules\chokidar\node_modules\fsevents):
npm WARN notsup SKIPPING OPTIONAL DEPENDENCY: Unsupported platform for fsevents@2.3.1: wanted {"os":"darwin","arch":"any"} (current: {"os":"win32","arch":"x64"})
added 1813 packages from 1109 contributors in 31.838s
Running eslint --fix to comply with chosen preset rules...
# ========================
> my-project@1.0.0 lint D:\webWorkspace\my-project
> eslint --ext .js,.vue src test/unit test/e2e/specs "--fix"
# Project initialization finished!
# ========================
To get started:
cd my-project
npm run dev
Documentation can be found at https://vuejs-templates.github.io/webpack
D:\webWorkspace>cd my-project
D:\webWorkspace\my-project>npm run dev
> my-project@1.0.0 dev D:\webWorkspace\my-project
> webpack-dev-server --inline --progress --config build/webpack.dev.conf.js
12% building modules 22/31 modules 9 active ...:\webWorkspace\my-project\src\App.vue{ parser: "babylon" } is deprecated; we now treat it as { parser: "babel" }.
95% emitting
DONE Compiled successfully in 4205ms 10:53:03 AM
I Your application is running here: http://localhost:8080
成功后,即可使用地址 http://localhost:8080 访问页面了,如下图:
7. 打包一个vue应用
使用npm run build 命令打包,会在根目录下生成dist文件夹包含打包的js, css和html页面。
更多推荐
所有评论(0)