Q:我给组件内的原生控件添加事件,怎么不生效了!!!


<!--比如用了第三方框架,或者一些封装的内置组件; 然后想绑定事件--> <!--// 错误例子1-->
<el-input placeholder="请输入特定消费金额 " @mouseover="test()"></el-input> <!--// 错误例子2-->
<router-link :to="item.menuUrl" @click="toggleName=''">
<i :class="['fzicon',item.menuIcon]"></i>
<span>{{item.menuName}}</span>
</router-link> <!--上面的两个例子都没法触发事件!!!-->
<!--究其原因,少了一个修饰符 .native-->
<router-link :to="item.menuUrl" @click.native="toggleName=''">
<i :class="['fzicon',item.menuIcon]"></i>
<span>{{item.menuName}}</span>
</router-link> <!--明明官方文档有的,一堆人不愿意去看,,Fuck-->
<!--https://cn.vuejs.org/v2/guide/components.html#给组件绑定原生事件-->

Q:我用了 axios , 为什么 IE 浏览器不识别(IE9+)

那是因为 IE 整个家族都不支持 promise, 解决方案:


npm install es6-promise // 在 main.js 引入即可
// ES6的polyfill
require("es6-promise").polyfill();

Q:Component template shold contain exactly one root element.If you are useing v-if on multiple elements , xxxxx

大体就是说,单组件渲染 DOM 区域必须要有一个根元素,不能出现同级元素.
可以用v-ifv-else-if指令来控制其他元素达到并存的状态

换个直白的解释,就是有一个唯一的父类,包裹者;

比如一个 div(父包含块) 内部多少个同级或者嵌套都行,但是最外层元素不能出现同级元素!!!!


Q:跨域问题怎么破!

这种问题老生常谈了,我就不细说了..大体说一下;

1: CORS , 前后端都要对应去配置,IE10+
2: nginx 反向代理,一劳永逸 <-- 线上环境可以用这个

线下开发模式,比如你用了vue-cli, 里面的 webpack 有引入了proxyTable这么个玩意,
也可以做接口反向代理

// 在 config 目录下的index.js

proxyTable: {
"/bp-api": {
target: "http://new.d.st.cn",
changeOrigin: true,
// pathRewrite: {
// "^/bp-api": "/"
// }
}
} // target : 就是 api 的代理的实际路径
// changeOrigin: 就是是变源,必须是...
// pathRewrite : 就是路径重定向,一看就知道

Q:路由模式改为history后,除了首次启动首页没报错,刷新访问路由都报错!

必须给对应的服务端配置查询的主页面..也可以认为是主路由入口的引导

官方文档也有,为毛总有人不喜欢去看文档,总喜欢做伸手党....FUCK

传送门 : Vue-Router history Mode


Q:我想拦截页面,或者在页面进来之前做一些事情,可以么?

Of course !!

各种路由器的钩子!! 传送门: 导航守卫;

当然,记忆滚动的位置也可以做到,详情翻翻里面的文档


Q:TypeError: xxx is not a function

这种问题明显就是写法有问题...能不能动点脑子!!


Q:Uncaught ReferenceError: xxx is not define

  • 实例内的 data 对应的变量没有声明
  • 你导入模块报这个错误,那绝逼是导出没写好

Q:Error in render function:"Type Error: Cannot read property 'xxx' of undefined"

这种问题大多都是初始化的姿势不对;

比如引入echart这些...仔细去了解下生命周期,再来具体初始化;

vue 组件有时候也会(嵌套组件或者 props传递初始化)..也是基本这个问题


Q:Unexpected token: operator xxxxx

大佬,这个一看就是语法错误啊.
基本都是符号问题.
一般报错会给出哪一行或者哪个组件


Q:npm run build之后不能直接访问

大佬!你最起码得在本地搭个服务器才能访问好么!!


Q:CSSbackground引入图片打包后,访问路径错误

因为打包后图片是在根目录下,你用相对路径肯定报错啊....
你可以魔改 webpack 的配置文件里面的static./static...但是不建议

你若是把图片什么丢到assets目录下,然后相对路径,打包后是正常的


Q:安装模块时命令窗口输出unsupported platform xxx

一般两种情况,node版本不兼容,系统不兼容;

解决方案: 要么不装,要么满足安装要求;


Q:Unexpected tab charater这些

一般是你用脚手架初始化的时候开了 eslint ;

要么遵循规则,要么改变规则;

要么直接把 webpack 里面的 eslint 检测给关闭了


Q:Failed to mount component: template or render function not defined

组件挂载失败,问题只有这么几个

组件没有正确引入; 挂载点顺序错了了;

自行动手排查


Q:Unknown custom element: <xxx> - did you register the component correctly?

组件没有正确引入或者正确使用,依次确认

  1. 导入对应的组件
  2. 在 components 内声明
  3. 在 dom 区域声明标签

Q: axiospost 请求后台接受不到!

axios默认是 json 格式提交,确认后台是否做了对应的支持;

若是只能接受传统的表单序列化,就需要自己写一个转义的方法...

当然还有一个更加省事的方案,装一个小模块qs


npm install qs -S // 然后在对应的地方转就行了..单一请求也行,拦截器也行...我是写在拦截器的.
// 具体可以看看我 axios 封装那篇文章 //POST传参序列化(添加请求拦截器)
Axios.interceptors.request.use(
config => {
// 在发送请求之前做某件事
if (
config.method === "post"
) {
// 序列化
config.data = qs.stringify(config.data); // ***** 这里转义
} // 若是有做鉴权token , 就给头部带上token
if (localStorage.token) {
config.headers.Authorization = localStorage.token;
}
return config;
},
error => {
Message({
// 饿了么的消息弹窗组件,类似toast
showClose: true,
message: error,
type: "error.data.error.message"
});
return Promise.reject(error.data.error.message);
}
);

Q:Invalid prop: type check failed for prop "xxx". Expected Boolean, got String.

这种问题一般就是组件内的 props 类型已经设置了接受的范围类型,
而你传递的值却又不是它需要的类型,写代码严谨些 OK?


Q: 过滤器可以用于DOM区域结合指令么?

// 不行,看下面的错误例子
<li v-for="(item,index) in range | sortByDesc | spliceText">{{item}}</li> // `vue2+`的指令只能用语 mustache`{{}}` , 正确姿势如下: <span>{{ message | capitalize }}</span>

Q: [...Array],...mapState,[SOME_MUTATION] (state) {},increment ({ commit }) {}这种写法是什么鬼!

出门左拐,ES6+(ES2015)的基础去过一遍..

上面依次:数组解耦,对象解耦,对象风格函数,对象解耦赋值传递


Q:Error in event handler for "click":"xxx"

这个问题大多都是你写的代码有问题.你的事件触发了.
但是组件内部缺少对应的实现或者变量,所以抛出事件错误.

解决方案:看着报错慢慢排查


Q: 组件的通讯有哪几种啊!!!

基本最常用的是这三种;

  1. 父传子: props
  2. 子传父: emit
  3. 兄弟通讯:
    • event bus: 就是找一个中间组件来作为信息传递中介
    • vuex: 信息树

传送门:


Q:vuex的用户信息为什么还要存一遍在浏览器里(sessionStorage or localStorage)

因为 vuex的 store 干不过刷新啊.
保存在浏览器的缓存内,若用户刷新的话,值再取一遍呗;


Q:"有 Vue + Vue Router + Vuex"或什么"express + vue + mongodb"的项目学习么

Github 一搜一大堆,提这些问题的人,不是培训机构的就是瞎进这行的人或者学生党;


Q:线上若是 nginx,如何部署?以及反向代理这些!!

传送门:一篇不大靠谱的nginx 1.11.10配置文件


Q:"我会 Vue 我还需要学习 jQuery 或者原生 JS 么"

jQuery还有很多公司在用,源码可以学习的地方很多;

原生 js 是根本,不管是哪个前端框架,最终都是 js 实现的;
只有基础扎实,才能学的比较深...

框架只是加快开发,提交效率,但不是你在这一行长期立足的根本;

前端的人不仅需要宽度,也要深度...这样才能走的更远....

Q:Vue ,React, Angular学习哪个好?哪个工作比较好找!

基础薄弱的,Vue 比较好上手
基础较好的,可以选择NG5或者React 16;

NG5需要学习typescriptrxjs,还用到比较多的新东西,比如装饰器,后端的注入概念.ng有自己的一整套 MVVM 流程;

VueReact核心只是view,可以搭配自己喜欢的

React的写法偏向函数式写法,还有 jsx,官方自己有 flow,当然也能搭配ts,我也没怎么接触..所以也有一定的学习成本;

至于哪个比较好找工作!!!告诉你..若是只会一个框架,那不是一个合格的前端;

人家要的是动手能力,解决能力!!!!技术和待遇是成正比的!!

颜值和背景,学历,口才可以加分..但是这些条件你必须要有的基础下才能考虑这些,不然就慢慢学;


Q:"首屏加载比较慢!!怎么破!打包文件文件比较大"

依次排除和确认:

  • 减少第三方库的使用,比如jquey这些都可以不要了,很少操作 dom,而且原生基本满足开发
  • 若是引入moment这些,webpack 排除国际化语言包
  • webpack 常规压缩js,css, 愿意折腾的还可以引入 dll 这些
  • 路由组件采用懒加载
  • 加入路由过渡和加载等待效果,虽然不能解决根本,但起码让人等的舒心一点不是么!!!

整体下来,打包之后一般不会太大;

但是倘若想要更快?那就只能采用服务端渲染(SSR)了,可以避免浏览器去解析模板和指令这些;
直接返回一个 html ....还能 SEO...

Q: Vue SPA 没法做优化(SEO)!有解决方案么

可以的,SSR(服务端渲染就能满足你的需求),因为请求回来就是一个处理完毕的 html

现在 vue 的服务端开发框架有这么个比较流行,如下

传送门:Nuxt.js


Q: Vue可以写 hybird App 么!

当然可以,两个方向.


Q: Vue 可以写桌面端么?

当然可以,有electronnode-webkit(nw);

我只了解过electron;


Q: Vue开发,项目中还需要 jQuery

分情况探讨:

  1. 若是老项目,只是单纯引入 Vue 简化开发的,依旧用吧...
  2. 重构项目?或者发起新项目的,真心没必要了.开发思路不一样,很多以前用 DOM 操作的现在基本数据驱动下,少量的 DOM 操作原生就能搞定...而且能减小打包体积,速度又快,何乐而不为!!!

Q:Vue PC(桌面)端,M(mobile:移动)端,用什么 UI 框架好啊!!!

PC

我推荐的只有两个 element UIiview

Mobile

Vux

当然还有很多,但是基本用户的认知度都不高,这三个比较流行


Q: Vue可以写微信小程序么,怎么搞起

可以的,社区也有人出了对应的解决方案,比如比较流行的方案wepy;
wepy你也可以理解为一个脚手架,让你的写小程序的方式更贴近你用vue-cli写 vue 的感觉...

传送门:wepy


Q:想要 mock 数据,直接请求 json文件 为什么不行!

当然不行,浏览器安全机制不允许,JS天生不能越权(NodeJS不能单纯说是JS)

你要 mock 数据,一般都有比较成熟的方案...传送门:


据说 Vue 3 打算用Proxy拦截器来做数据拦截及响应..这样可以检测到更多数据类型的响应;不过 IE系列全军覆没,polyfill 都不行

Vue 目前最新 2.5.3 核心库已适配 typescript 2.6; 但是周边库没跟上..你想要用 ts+vue开发已经没什么特别的坑了...但是组件基本都是要自己去写..第三方没有加上对应的声明一堆问题

Vue 常见问题汇总的更多相关文章

  1. Nuxt.js的踩坑指南(常见问题汇总)

    本文会不定期更新在nuxt.js中遇到的问题进行汇总.转发请注明出处,尊重作者,谢谢! 强烈推荐作者文档版踩坑指南,点击跳转踩坑指南 在Nuxt的官方文档中,中文文档和英文文档都存在着不小的差异. 1 ...

  2. CentOS安装Oracle数据库详细介绍及常见问题汇总

    一.安装前准备 1.软件硬件要求 操作系统:CentOS 6.4(32bit)Oracle数据库版本:Oracle 10g(10201_database_linux32.zip)最小内存:1G(检查命 ...

  3. SVN集中式版本控制器的安装、使用与常见问题汇总

    SVN是Subversion的简称,是一个开放源代码的版本控制系统,它采用了分支管理系统,集中式版本控制器 官方网站:https://www.visualsvn.com/ 下载右边的服务器端,左边的客 ...

  4. H5项目常见问题汇总及解决方案

    H5项目常见问题汇总及解决方案 H5   2015-12-06 10:15:33 发布 您的评价:       4.5   收藏     4收藏 H5项目常见问题及注意事项 Meta基础知识: H5页 ...

  5. Installshield脚本拷贝文件常见问题汇总

    原文:Installshield脚本拷贝文件常见问题汇总 很多朋友经常来问:为什么我用CopyFile/XCopyFile函数拷贝文件无效?引起这种情况的原因有很多,今天略微总结了一下,欢迎各位朋友跟 ...

  6. MVC 网站部署常见问题汇总

    一:TGIShare项目是一个MVC5的网站程序,部署在了IIS上,使用的Windows验证方式,并在本机设置了计划任务定时调用某个地址执行命令.问题汇总如下: 1.Window Server 200 ...

  7. J2EE进阶(十)SSH框架整合常见问题汇总(一)

    SSH框架整合常见问题汇总(一) 前言 以下所列问题具有针对性,但是遇到同类型问题时均可按照此思路进行解决. HTTP Status 404 - No result defined for actio ...

  8. mysql进阶(十六)常见问题汇总

    mysql进阶(十六)常见问题汇总 MySQL视图学习: http://www.itokit.com/2011/0908/67848.html 执行删除操作时,出现如下错误提示: 出现以上问题的原因是 ...

  9. 转---CentOS安装Oracle数据库详细介绍及常见问题汇总

    一.安装前准备 1.软件硬件要求 操作系统:CentOS 6.4(32bit)Oracle数据库版本:Oracle 10g(10201_database_linux32.zip)最小内存:1G(检查命 ...

随机推荐

  1. 【DB2】查看表空间对应的物理文件地址

    使用的命令: db2 list tablespaces show detail db2 list tablespace containers for [Tablespace ID] [show det ...

  2. VREP中的二维激光雷达

    目前,轮式机器人的研究中已经大量使用激光雷达辅助机器人的避障导航,考虑到使用成本,一般二维激光雷达使用较多,如下图.由于只能扫描一个平面,如果想用二维激光雷达获取环境三维点云,则需要通过移动机器人或加 ...

  3. java第二节 基本数据类型

    class Lesson2 { public static void main(String[] args) { //----------------------------------- //@Da ...

  4. Python实现鸢尾花数据集分类问题——使用LogisticRegression分类器

    . 逻辑回归 逻辑回归(Logistic Regression)是用于处理因变量为分类变量的回归问题,常见的是二分类或二项分布问题,也可以处理多分类问题,它实际上是属于一种分类方法. 概率p与因变量往 ...

  5. 谈UIView Animation编程艺术

    一.大小动画(改变frame) -(void)changeFrame{ CGRect originalRect = self.anView.frame; CGRect rect = CGRectMak ...

  6. Linux下网卡混杂模式设置和取消

    工作中发现一个网卡工作状态不对了,查看了一下,发现这个网卡和正常工作的网卡  信息不一样,它显示的居然是混杂模式,而正常工作的是  running 模式 ,所以来了解下混杂模式怎么取消... 下文来自 ...

  7. Oracle中INTERSECT,MINUS,UNION,UNION ALL用法

    intersect 就是交集minus 就是差集 交集就是两个结果集中都有的元素 比如 select uid from tb1 intersect select uid from tb2 那么既存在t ...

  8. java结合使用Jsonp的例子

    更多:js跨域问题解释 解决方案值使用jsonp或jQuery Jsonp和java操作例子 介绍JSONP之前,先简单的介绍一些JSON.JSON是JavaScript Object Notatio ...

  9. 微信支付HTTPS服务器证书验证指引

    1. 背景介绍 2. 常见问题 3. 验证证书 4. 安装证书 背景介绍 微信支付使用HTTPS来保证通信安全, 在HTTPS服务器上部署了由权威机构签发的证书, 用于证明微信支付平台的真实身份. 商 ...

  10. 微信公众平台HTTPS方式调用配置免费https服务器

    微信公众平台数据传输安全,提高业务安全性,公众平台将不再支持HTTP方式调用.避免影响正常使用中含有HTTP方式调用的服务,请开发者尽快调整,将现有通过HTTP方式调用的切换成HTTPS调用,平台将于 ...