使用 Vue.js 做项目的时候,一个页面是由多个组件构成的,所以在跳转页面的时候,并不适合用传统的 href,于是 vue-router 应运而生。
官方文档: https://router.vuejs.org/zh-cn/essentials/getting-started.html
即使成功无望 我亦欣然上场
使用 Vue.js 做项目的时候,一个页面是由多个组件构成的,所以在跳转页面的时候,并不适合用传统的 href,于是 vue-router 应运而生。
官方文档: https://router.vuejs.org/zh-cn/essentials/getting-started.html
Vue Cli 3 官方文档:https://cli.vuejs.org/zh/guide/
一、安装 @vue/cli
更新到 3.x 之后,vue-cli 的包名从 vue-cli 改成了 @vue/cli
如果之前全局安装了旧版本的 vue-cli (1.x 或 2.x),首先需要使用以下命令卸载掉
如果没有安装旧版本的 vue-cli 可以跳过卸载直接安装
1 | npm uninstall vue-cli -g |
然后重新安装新版本的 @vue/cli
1 | npm install -g @vue/cli |
1.在 vue.config.js
中设置正确的 publicPath
。
如果打算将项目部署到 https://<USERNAME>.github.io/
上 , publicPath
将默认被设为 "/"
,你可以忽略这个参数。
如果打算将项目部署到 https://<USERNAME>.github.io/<REPO>/
上, (换句话说 仓库地址为 https://github.com/<USERNAME>/<REPO>
), 可将 publicPath
设为 "/<REPO>/"
。 举个例子, 如果仓库名字为 “my-project”,vue.config.js
的内容应如下所示:
1 | module.exports = { |
注意:此处是将原来的vue.config.js文件中的所有内容删除,然后复制上述内容进去,修改仓储名称即可
我们知道bind,call,apply的作用都是用来改变this指向的,那为什么要改变this指向呢?请看下面的例子:
1 | var name="lucy"; |
可以观察到,正常情况下 say 方法中的 this 是指向调用它的 obj 对象的,而定时器 setTimeout 中的 say 方法中的 this 是指向window对象的(在浏览器中),这是因为 say 方法在定时器中是作为回调函数来执行的,因此回到主栈执行时是在全局执行上下文的环境中执行的,但我们需要的是 say 方法中 this 指向obj对象,因此我们需要修改 this 的指向。
apply接受两个参数,第一个参数是this的指向,第二个参数是函数接受的参数,以数组的形式传入,且当第一个参数为null、undefined的时候,默认指向window(在浏览器中),使用apply方法改变this指向后原函数会立即执行,且此方法只是临时改变this指向一次。
日常用法:改变this指向
示例:
回调函数绑定this指向:
1 | var name="martin"; |
小技巧:改变参数传入方式
示例:
求数组中的最大值:
1 | var arr=[1,10,5,8,3]; |
其中Math.max函数的参数是以参数列表,如:Math.max(1,10,5,8,3)的形式传入的,因此我们没法直接把数组当做参数,但是apply方法可以将数组参数转换成列表参数传入,从而直接求数组的最大值。
call方法的第一个参数也是this的指向,后面传入的是一个参数列表(注意和apply传参的区别)。当一个参数为null或undefined的时候,表示指向window(在浏览器中),和apply一样,call也只是临时改变一次this指向,并立即执行。
示例:
1 | var arr=[1,10,5,8,3]; |
采纳以参数列表的形式传入,而apply以参数数组的形式传入。
bind方法和call很相似,第一参数也是this的指向,后面传入的也是一个参数列表(但是这个参数列表可以分多次传入,call则必须一次性传入所有参数),但是它改变this指向后不会立即执行,而是返回一个永久改变this指向的函数。
示例:
1 | var arr=[1,10,5,8,12]; |
可以看出,bind方法可以分多次传参,最后函数运行时会把所有参数连接起来一起放入函数运行。
实现bind方法(面试题):
简易版
1 | Function.prototype.bind=function () { |
完美版
1 | //实现bind方法 |