1,什么是node.js,以及npm

简单的来说Node.js就是运行在服务端的JavaScript,是基于Chrome V8引擎的.npm是Node.js包的管理工具.

2,npm的安装和更新

Node.js下载安装Node.js官网下载安装.npm自带的包管理工具.

  • node - v 查看Node.js版本信息;
  • npm - v 查看npm版本信息

更新到npm指定版本:

  • npm install npm@5.3.0 - g
  • npm install npm@latest - g更新最新的稳定版本

npm常用操作

之前我们用jQuery或者Bootstrap用cdn或者直接手动下载并放入项目,而且要管理版本.有了npm,我们管理自己的依赖包以及版本更加简单

到自己项目下,进行下列命令:

  • npm init -y 输入-y使用默认配置项生成package.json文件.
  • npm i jquery@0.0.0 简写install为 i 下载依赖 不写@默认最新版本
  • npm uninstall jquery 卸载依赖包
  • npm update jquery 更新依赖包
  • npm list 列出已安装的依赖
  • npm install webpack--D保存为开发环境依赖
  • 老版本需要--save参数 现在不需要来了

我们的项目目录下会生成一个node_modules目录,我们用npm下的包会在这个目录下.

我们所有的依赖信息放在package.json文件中,包括我们所有的依赖以及版本

如果我们删掉node_modules目录,可以使用npm i 来下载所有依赖.

3,npm常用配置

当我们用npm init的时候用了参数-y, 如果不用-y我们可以进行一些配置,在我们的package.json文件中有很多配置项

  • name 项目名字 中间不能有空格只能用小写
  • version 项目版本
  • description 项目描述信息
  • main 项目的入口文件
  • scripts指定命令的快捷方式 npm run test  test是scripts里的键名 值为具体命令
  • auther 作者
  • license 许可证
  • dependencies 生成环境依赖的包及版本信息
  • devDependencies 开发环境的依赖

4,webpack3

webpack:是一个模块打包器,他将根据模块的依赖关系静态分析,然后将这些模块按照指定的规则生产成静态资源,

4.1,安装和配置

webpack是跑在Node.js环境下的,所以确定有node环境

安装方式:

  • npm install webpack- g 全局安装
  • webpack<要打包文件><打包后文件>全局这种方式进行打包
  • npm install webpack 在自己的项目下npm init后再下载webpack这就是局部安装
  • node_modules/.bin/webpack<要打包文件><打包后文件>项目里要打包文件是入口文件
  • 路径太长 太烦 可以自定义命令 在package.json中文件的scripts下面定义

4.2,entry和output

entry是入口文件,output是出口文件,我们可以把命令写在webpack.config.js中

module.export = {
// 所有的入口文件
entry: {
home: './main.js',
login: './login.js',
},
// 出口文件
output: {
filename: '[name].bundle.js',
path: __dirname + '/dist',
}
}
// backage.json 下的scripts
scripts: {
"pack": "node_moudles/.bin/webpack --watch"
} // 运行命令
npm run pack

5,webpack4

webpack的新特性

5.1,webpack不在单独使用,需要webpack-cli

  • 全局安装  npm install webpack   webpack-cli-g-D
  • 局部安装  npm install webpack   webpack-cli- D

5.2,增加区分模式(development, production)

  • webpack  mode development/production进行模式切换
  • development开发者模式,打包默认不压缩代码
  • production 生产者模式 上线时使用,压缩代码,默认是这个模式

5.3,固定入口目录为src,与入口默认文件index.js,打包后文件在新增的dist目录下

  当只有一个入口文件也就是src/index.js时,无需增加webpack.config.js

6,Vue-cli

Vue-cli是官方提供的快速构建这个单页面应用的脚手架

  • 前提是已经安装了node.js否则npm都用不了
  • 1,使用npm全局安装vue-cli,
    •   npm install-g vue-cli
  • 2,安装完成后在自己的工作空间里
    •   vue init webpack vue-demo   输入命令后进入安装阶段,需要用户输入一些信息
  • 3,切换到我们的目录下
    •   cd vue-demo
    • npm run dev

6.1,目录结构

  • build里面是一些操作文件,使用npm run *时其实执行的就是这里的文件
  • config配置文件,执行文件需要的配置信息
  • src资源文件,所有的组件以及所有的图片都在这个文件夹下
  • node_modules 项目依赖包
  • static静态文件
  • package.json依赖包的json文件

7,Vue-cli配置jquery,bootstrap

7.1,下载安装

  • npm install jquery
  • npm install  bootstrap

7.2,修改build/webpackage.base.conf.js

const webpack = require('webpack')
// 在module.exports里添加插件
plugins: [
new webpack.ProvidePlugin({
$: "jquery",
jQuery: "jquery",
"windows.jQuery": "jquery",
// Popper: ['popper.js', 'default']
})
],
// *******下面是如果手动下载bootstrap用的*******
resolve: {
extensions: ['.js', '.vue', '.json'],
alias: {
'vue$': 'vue/dist/vue.esm.js',
'@': resolve('src'),
// 如果是手动下载的bootstrap需要添加这个配置
// 'assets': path.resolve(__dirname, '../src/assets'),
// 'jquery': 'jquery/src/jquery'
}
},

7.3,修改主程序的就是文件

import $ from 'jquery'
import 'bootstrap/dist/css/bootstrap.min.css'
import 'bootstrap/dist/js/bootstrap.min.js'

8,vue-cli 3.0

8.1,下载安装

  • npm install-g@vue/cli
  • 报错 npm error 可运行下面命令
  • npm cache clean--force && npm cache verify

8.2,创建项目

  • vue create 项目名
  • 之后会出现很多选项,根据自己的偏爱去选择

8.3,目录结构及其配置文件

  • vue-cli3目录更加简单
  • 我们手动在项目下创建vue.config.js的配置信

8.4,vue-cli3配置jquery.bootstrap

  据说和vue-cli2一样

总之:在运行vue-cli和webpack都要运行node.js

  1,先下载node.js这是一个步骤如下图

一,在命令行输入命令:

  node.js/npm

    npm

    管理工作目录   --->   npm init -y

    下载包   ------>npm i xxxx@0.0.0

    卸载      ------->npm uninstall xxxx

    更新      ------->npm update xxxx

  webpack

    下载      -------->npm i webpack webpack-cli

    打包默认的入口文件   ------->src目录下的index.js

    出口文件   ------->dist目录的main.js

  vue-cli    帮助开发人员快速搭建项目的脚手架工具

    下载      --------->npm i vue-cli

    用vue-cli帮助我们创建项目   ------->vue init webpack xxxx

    启动项目   -------->npm run dev 

9,vuex

  • vuex是专门Vue.js设计的集中状态管理架构,我们把它理解为在data中需要共享给其他组件使用额度部分,Vuex和单纯的全局对象有以下不同:
    1. Vuex的状态存储是响应式的,当Vue组件从store中读取状态的时候,若store中的状态发生了变化,那么响应的组件也会相应的得到高效更新(一荣俱荣,一损俱损,所以说Vuex的存储是响应式的)
    2. 不能直接改变store中的状态,改变store中的状态唯一途径就是显示的提交(commit)mutation,这样使得我们可以方便的跟踪每一个状态的变化,从而让我们能够实现一些工具来帮助我们了解我们的应用
  • vuex的安装和使用

命令行:npm i vuex

// 第一步导入vuex
import vuex from "vuex"
// 第二步vue使用vuex
vue.use(vuex)
// 第三步实例化仓库
new vuex.Store({
state: {}, getter: {}, mutations:{}
}) // 第四步实例化一个Vue对象
// 注册仓库
new Vue({
el:"#app".
store
})
  • 获取仓库数据
    1. this.$store.state.xxx
    2. this.$store.getters.xxx
  • 改变仓库中的数据
    1. 组件向仓库提交修改数据
      1. this.$store.commit("事件名称", data)
    2. 在仓库的mutations中
      1. mutations: {"事件名称":function(state, data){修改state中的数据}}
    3. 注意计算属性
      1. 仓库中的数据建议都放在计算属性中
  • 参数说明State
    • state是保存我们data中需要共享的数据,由于Vuex的存储是响应式的,从store实例中读取状态的最简单方式,就是在计算属性中返回某个状态.this.$store.state.count
// 创建一个组件
const Counter = {
template: `<div>{{ count }}</div>`,
computed: {
count(){
return this.$store.state.count
}
}
};
  • Getter参数的说明
  • 有时候我们需要从store中的state中派生出一些状态,例如对数据进行简单的计算,并且很多组件都需要用到此方法,要么复制这个函数,要么抽取到一个公共函数,多出导入,但是vuex提供了更加方便的方法 ,getter,就像计算属性一样,getter的返回值会根据它的依赖被缓存起来,只有它的依赖发生改变时,才会重新计算,
  • Getter会接收state作为第一个参数
import Vue from 'vue'
import Vue_x from "vuex" Vue.use(Vue_x); export default new Vue_x.Store({
state: {
count: 20,
},
// 通过 this.$store.getters.my_func
getters: {
my_func: function (state) {
return state.count * 2
}
}, });
  • Getters也可以接收getters为第二个参数
import Vue from 'vue'
import Vue_x from "vuex" Vue.use(Vue_x); export default new Vue_x.Store({
state: {
count: 20,
},
// 通过 this.$store.getters.my_func
getters: {
my_func: function (state) {
return state.count * 2
},
// 通过 this.$store.getters.my_func_count
my_func_count: function (state, getters) {
return getters.my_func.length
}
}, });
  • Mutation
  • 更改vuex中的store中的状态的唯一方法是提交mutation.
  • 每个mutation都有一个字符串的事件类型(type),和一个回调函数handler
  • 也就是说我们要触发mutation中定义的方法(type),然后才会执行这个方法(handler)
  • 这个方法就是我们要更改状态的地方, 它会接收state为第一个参数,后面接收其他参数
import Vue from 'vue'
import Vue_x from "vuex" Vue.use(Vue_x); export default new Vue_x.Store({
state: {
count: 20,
},
// 需要通过 this.$store.commit('increment', 10)
mutations: {
increment (state, n) {
// 变更状态
state.count += n
}
} });
  • Mutation需要遵循Vue的响应规则
  • 既然Vuex中的store中的状态是响应式的, name当我们状态变更时, 监视状态的vue组件也会更新.这就意味着vuex中的mutation也需要与使用vue一样注意一些注意事项 :
    1. 最好提前在你的 store中初始化好所有需要的属性
    2. 当对象需要添加属性时,你应该使用:
      1. Vue.set(obj, 'newProp', 123)
      2. 以新对象代替老对象 state.obj={...state.obj, newProp:123}

10,axios的简单使用

  1. 基于Promise的HTTP请求客户端, 可以同时在浏览器额 node.js中使用
  2. 使用npm安装axios:   npm  install  axios -D
  3. 基本的配置
  4. // main.js
    import axios from "axios" Vue.prototype.$axios = axios // 组件中
    methods: {
    init () {
    this.$axios({
    method: "get",
    url: "/user"
    })
    },
    };
  5. 基本的使用
    • get请求
test(){
this.$axios.get(this.$store.state.apiList.course,{
params: {
id: 123,
}
}).then(function (response) {
// 请求成功回调函数
}).catch(function (response) {
// 请求失败的回调函数
})
}
    • post请求
test(){
this.$axios.post(this.$store.state.apiList.course,{
course_title: "Python",
course_price: "19.88"
}).then(function (response) {
// 请求成功回调函数
}).catch(function (response) {
// 请求失败的回调函数
})
}
    • 发送多个并发请求
function getCourse(){
return this.$axios.get('/course/12')
}
function getCourse_all() {
return this.$axios.get('/course')
}
this.$axios.all([getCourse_all(),getCourse()])
.then().catch()
    • axios.request那个人喜欢的
methods: {
init(){
var that = this
this.$axios.request({
url: that.$store.state.apiList.course,
method: 'get'
}).then(function (data) {
if (data.status === 200){
that.courseList = data.data
}
}).catch(function (reason) {
console.log(reason)
})
}
},
  • axios是实现ajax技术的工具

    • 下载: npm i axios
    • 导入: import axios from "axios"
    • 在vue的原型链中加入方法:Vue.prototype.$axios = axios
    • 发送请求:this.$axios.request({url, method}).then(function(){}).catc(function(){})

  

             

npm, webpack, vue-cli, vue-x, axios的更多相关文章

  1. vue cli & vue 3.x

    vue cli & vue 3.x https://cli.vuejs.org/dev-guide/ui-api.html#ui-api https://cli.vuejs.org/zh/gu ...

  2. 使用Vue CLI 3将基于element-ui二次封装的组件发布到npm

    前言:之前在网上找的好多都是基于vue-cli 2.x的,而使用vue-cli 3的文章比较少,Vue CLI 3 中文文档,所以我在自己尝试的时候把几篇文章结合了一下,调出来了我想要的模式,也就是V ...

  3. 如何使用@vue/cli 3.0在npm上创建,发布和使用你自己的Vue.js组件库

    译者按: 你可能npm人家的包过成千上万次,但你是否有创建,发布和使用过自己的npm包? 原文: How to create, publish and use your own VueJS Compo ...

  4. vue cli 3

    介绍 Vue CLI 是一个基于 Vue.js 进行快速开发的完整系统 通过 @vue/cli 搭建交互式的项目脚手架. 通过 @vue/cli + @vue/cli-service-global 快 ...

  5. Vue Cli安装以及使用

      因为公司项目要用vue框架,所以会用vue-cli来新建项目.用过vue的都知道,要全局安装vue以及脚手架vue-cli,然后执行vue init webpack projectname来新建v ...

  6. Vue CLI 介绍安装

    https://cli.vuejs.org/zh/guide/ 介绍 警告 这份文档是对应 @vue/cli 3.x 版本的.老版本的 vue-cli 文档请移步这里. Vue CLI 是一个基于 V ...

  7. @vue/cli 4.0.5 学习记录

    1. Vue CLI (@vue/cli) 是一个全局安装的 npm 包,提供了终端里的 vue 命令.Vue CLI 插件的名字以 @vue/cli-plugin- (内建插件) 或 vue-cli ...

  8. 13. Vue CLI脚手架

    一. Vue CLI 介绍 1. 什么是Vue CLI? Vue CLI 是一个基于 Vue.js 进行快速开发的完整系统.Vue CLI 致力于将 Vue 生态中的工具基础标准化.它确保了各种构建工 ...

  9. Vue CLI 是如何实现的 -- 终端命令行工具篇

    Vue CLI 是一个基于 Vue.js 进行快速开发的完整系统,提供了终端命令行工具.零配置脚手架.插件体系.图形化管理界面等.本文暂且只分析项目初始化部分,也就是终端命令行工具的实现. 0. 用法 ...

  10. Vue CLI 5 和 vite 创建 vue3.x 项目以及 Vue CLI 和 vite 的区别

    这几天进入 Vue CLI 官网,发现不能选择 Vue CLI 的版本,也就是说查不到 vue-cli 4 以下版本的文档. 如果此时电脑上安装了 Vue CLI,那么旧版安装的 vue 项目很可能会 ...

随机推荐

  1. 《Java编程思想》笔记14.类型信息

    运行时类型信息使得你可以在运行时发现和使用类型信息,主要有两种方式: "传统的"RTTI,它假定我们在编译时已经知道了所有的类型: "反射"机制,它允许我们在运 ...

  2. Python面向对象之文件操作

    文件的概念 文件的概念和作用 计算机的文件,就是存储在某种长期存储设备上的一段数据:长期存储设备包括:U盘,硬盘,移动硬盘,光盘,等: 文件的作用:将数据长期保存,在需要的时候使用: 文件的存储方式 ...

  3. uC/OSii之任务划分

    满足以下几个指标将会使软件设计比较简洁高效. 满足实时性指标 任务数目合理 简化软件系统 降低资源需求 设备依赖性划分:主要是对于一些输入输出设备进行划分,输入输出设备分为主动型和被动性.主动型有一个 ...

  4. 构造MaxTree

    链接:https://www.nowcoder.com/questionTerminal/a502c7c3c65e41fdaf65eec9e0654dcb 来源:牛客网 [编程题]构造MaxTree ...

  5. jQuery常用案例总结

    模态对话框 <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF ...

  6. ES6(对象扩展)

    ES6(对象(object)新增特性) 1.简介表示法 o,k 为属性:这种为无方法的情况. 这种为有方法. 2.属性表达式 ES6中,[a]就是 b . 3.新增API 1.数组也是引用类型 2.O ...

  7. Codeforces Round #321 (Div. 2)-A. Kefa and First Steps,暴力水过~~

    A. Kefa and First Steps time limit per test 2 seconds memory limit per test 256 megabytes input stan ...

  8. 『NYIST』第八届河南省ACM竞赛训练赛[正式赛一]-CodeForces 237C,素数打表,二分查找

    C. Primes on Interval time limit per test 1 second memory limit per test 256 megabytes input standar ...

  9. JS Enter键跳转 控件获得焦点

    //回车跳转 jQuery(document).ready(function () { //$(':input:text:first').focus(); jQuery(':input:enabled ...

  10. 【UTR #2】[UOJ#278]题目排列顺序 [UOJ#279]题目交流通道 [UOJ#280]题目难度提升

    [UOJ#278][UTR #2]题目排列顺序 试题描述 “又要出题了.” 宇宙出题中心主任 —— 吉米多出题斯基,坐在办公桌前策划即将到来的 UOI. 这场比赛有 n 道题,吉米多出题斯基需要决定这 ...