心血来潮就写点吧,不然。。。emmm,就太监了吧。。。
-
🙏生命周期相关--小tips:
- 组件创建完成时(created),data 已经被 observed
-
v-ifVSv-show:-
v-if是“真正”的条件渲染,因为它会确保在切换过程中条件块内的事件监听器和子组件适当地被销毁和重建。v-if也是惰性的:如果在初始渲染时条件为假,则什么也不做——直到条件第一次变为真时,才会开始渲染条件块。 -
v-show就简单得多——不管初始条件是什么,元素总是会被渲染,并且只是简单地基于CSS进行切换。
一般来说,
v-if有更高的切换开销,而v-show有更高的初始渲染开销。因此,如果需要非常频繁地切换,则使用v-show较好;如果在运行时条件很少改变,则使用v-if较好。 -
-
如果你恰好使用了
webpack(或在内部使用了webpack的 Vue CLI 3+),那么就可以使用require.context只全局注册这些非常通用的基础组件。这里有一份可以让你在应用入口文件 (比如src/main.js) 中全局导入基础组件的示例代码:import Vue from 'vue' import upperFirst from 'lodash/upperFirst' import camelCase from 'lodash/camelCase' const requireComponent = require.context( // 其组件目录的相对路径 './components', // 是否查询其子目录 false, // 匹配基础组件文件名的正则表达式 /Base[A-Z]\w+\.(vue|js)$/ ) requireComponent.keys().forEach(fileName => { // 获取组件配置 const componentConfig = requireComponent(fileName) // 获取组件的 PascalCase 命名 const componentName = upperFirst( camelCase( // 获取和目录深度无关的文件名 fileName .split('/') .pop() .replace(/\.\w+$/, '') ) ) // 全局注册组件 Vue.component( componentName, // 如果这个组件选项是通过 `export default` 导出的, // 那么就会优先使用 `.default`, // 否则回退到使用模块的根。 componentConfig.default || componentConfig ) })
-
HTML 中的 attribute 名是大小写不敏感的,所以浏览器会把所有大写字符解释为小写字符。这意味着当你使用 DOM 中的模板时,
camelCase(驼峰命名法) 的 prop 名需要使用其等价的 kebab-case (短横线分隔命名) 命名:Vue.component('blog-post', { // 在 JavaScript 中是 camelCase 的 props: ['postTitle'], template: '<h3>{{ postTitle }}</h3>' }) <!-- 在 HTML 中是 kebab-case 的 --> <blog-post post-title="hello!"></blog-post>
重申一次,如果你使用字符串模板,那么这个限制就不存在了。
-
对于绝大多数 attribute 来说,从外部提供给组件的值会替换掉组件内部设置好的值。所以如果传入
type="text"就会替换掉type="date"并把它破坏!庆幸的是,class和styleattribute 会稍微智能一些,即两边的值会被合并起来,从而得到最终的值:form-control date-picker-theme-dark。
-
axios访问不到本地的文件: A: 在vue-cli升级至@3+后,静态文件放在public文件夹下,故请求的根路径变成了: http://localhost:8080/public/api 记得将静态文件放在public下,而不再是static -
vue/cli创建项目时报错:Failed to check for updates,且导致项目创建失败
**A:**找到
.vuerc文件,查看详细信息:- 淘宝镜像源是否启用
- 包管理工具是npm还是yarn
- vue/cli内置的包管理是yarn,yarn又是hadoop集群的资源管理系统,故查看是否是系统变量中hadoop的变量路径导致vue/cli使用了hadoop的yarn
-
getter在通过属性访问时是作为Vue的响应式系统的一部分缓存其中的。getter在通过方法访问时,每次都会去进行调用,而不会缓存结果。
-
history模式下
Vue组件内守卫beforeRouteUpdate不起作用A: history模式下目前确实不行,改为hash模式下,当设置的该相关路由改变时会触发
-
重定向与别名:
const router = new VueRouter({ routes: [ { path: '/a', redirect: '/b'}, // 重定向 { path: '/a', component: A, alias: '/b' } // 别名 ] })
重定向: 访问/a时,跳到/b(虽然不严谨,反正这么个表现), URL上也会改为真正的/b 别名: 访问/a时, 就是/a这个页面,访问/b时,实则为访问/a的页面,但URL上仍保持着/b的名字
-
完整的导航解析流程:
- 导航被触发。
- 在失活的组件里调用
beforeRouteLeave守卫。 - 调用全局的
beforeEach守卫。 - 在重用的组件里调用
beforeRouteUpdate守卫 (2.2+)。 - 在路由配置里调用
beforeEnter。 - 解析异步路由组件。
- 在被激活的组件里调用
beforeRouteEnter。 - 调用全局的
beforeResolve守卫 (2.5+)。 - 导航被确认。
- 调用全局的
afterEach钩子。 - 触发 DOM 更新。
- 用创建好的实例调用
beforeRouteEnter守卫中传给next的回调函数。
-
在自定义路由跳转事件时,触发事件后浏览器会报错:
**Uncaught (in promise) NavigationDuplicated:。。。。**解决方法: 据翻看大佬的解释,vue-router≥3.0版本回调形式以及改成promise api的形式了,返回的是一个promise,如果没有捕获到错误,控制台始终会出现如图的警告,针对于路由跳转相同的地址,目前的解决方案:this.$router.push('/location').catch(err => { console.log(err) })import Router from 'vue-router' const originalPush = Router.prototype.push Router.prototype.push = function push(location) { return originalPush.call(this, location).catch(err => err) }
-
远程关联 : 获取到
github仓库地址后,将本地仓库与github仓库关联输入指令:
git remote add your-warehouse-address -
git或gitlab修改密码之后,报错remote: HTTP Basic: Access denied,fatal: Authentication failed for ‘git或gitlab地址’:
方案一:
方案二:
-
git config --system --unset credential.helper git config --global credential.helper store再push就会提示输入用户名和新密码。
-
