vue中遇到的坑
如何解决在vue中替换图片、一个使用base64,而我们使用zepto之后,src找不到资源,因为已经打包了,难道强行写base64。
1. 引入文件时语法很重要!
import "FooterMenu" from '@components/Menu';
import FooterMenu from '@components/Menu';
即在页面组件中引入一个FooterMenu组件, 我们引入时应该引入的一个变量作为标签,而不能再FooterMenu上添加引号!! 在这里浪费了很多时间。
2. 在一个单页面组件中不需要style,但必须要script。
即在.vue文件中,我们可以没有style,但是必须要有script来利用 exports default 来导出模块,否则就会出错。
补充:
<transition name="fade">
<div class="pay-model" v-show="ifpay">
<div class="pay-style">
<div v-if="payArr[payArr.length - 3] == 1">
<input type="radio" name="settleChoose" checked = "checked" data-value='' id="wechat" value="微信支付" v-model="style">
<label for="wechat" >微信支付</label>
</div>
<div v-if="payArr[payArr.length - 2] == 1">
<input type="radio" name="settleChoose" id="alipay" data-value='' value="支付宝支付" v-model='style'>
<label for="alipay" >支付宝支付</label>
</div>
<div v-if="payArr[payArr.length - 1] == 1">
<input type="radio" name="settleChoose" id="tohome" data-value='' value="货到付款" v-model='style'>
<label for="tohome">货到付款</label>
</div>
</div>
</div>
</transition>
在这里,如果style的值为初始值 "", 即为空,那么我们及时使用这里的checked = "checked"也无法自动选中,解决方法:如果我们希望在打开模态框之后的微信支付是默认的,那么我们就可以将 style 的初始值设置为 “微信支付”, 这样就没有什么问题了。
补充:
<div v-if="payArr[payArr.length - 2] == 1">
<label class="pay-lable" >
<input type="radio" v-bind:checked = 'curPayMethod == 2' name="choosePay" value="2">
支付宝支付</label>
</div>
<div v-if="payArr[payArr.length - 3] == 1">
<label class="pay-lable" >
<input type="radio" v-bind:checked = 'curPayMethod == 4' name="choosePay" value="4">
微信支付</label>
</div>
<div v-if="payArr[payArr.length - 1] == 1">
<label class="pay-lable">
<input type="radio" v-bind:checked = 'curPayMethod == 1' name="choosePay" value="1">
修改为货到付款</label>
</div>
label的for对应于input的id,如果说不能正常使用,其实我们也可以直接将input写进label里去,这样会更加方便,不再需要使用 for 和 id 了。
3. 当我们在路由中配置了不同的router-link对应于不同的组件的时候,会发现npm run dev之后什么都没有,比如我的路由如下:
export default new Router({
routes: [
{
path: '/Mall',
component: Mall
},
{
path: '/personal-center',
component: personalCenter
},
{
path: '/order',
component: AlipayHint
},
{
path: '/commodity',
component: Commodity
}
]
});
运行之后,是空白页,这是因为路由中并没有配置一进来是“/”的路由,所以什么都没有显示,这时就需要重定向了。如下所示:
routes: [
{
path: '/Mall',
component: Mall
},
{
path: '/personal-center',
component: personalCenter
},
{
path: '/order',
component: AlipayHint
},
{
path: '/commodity',
component: Commodity
},
{
path: "/",
redirect: "/commodity"
}
]
即我们需要重定向的时path中的值,而不是component中的值。
4. 在v-for下的列表中,如何向方法传递参数?
(1) 我们可以在一个list中绑定 v-for="item,index in items", 这样,我们就可以获取到相应的item和index(从0开始),另外,如果我们希望向list中的某个v-on:click = "handler" 传递参数,可以直接传递,比如: v-on:click="handler(index)", 这样就可以向methods下的handler传递参数了。
(2) 我们还可以传递$event直接给hanlder,然后通过e.currentTarget获取到这个元素。
5. 如何使用vuex、使用store中的数据、替换store中的数据?
vuex大家都不陌生,比如我在一个store的state中存储了items为一个空数组,然后在组件中循环数组中的每一个元素并展示出来,然后再通过axios获取到数据之后更新store,这样数组中就有元素了。
最开始我使用的思路如下所示:
const state = {
totalPrice: ,
items: [],
//.... 其他的state
}
然后通过axois获取items,获取到之后更新:
.then(function (response) {
if (response.data.code == ) {
items = response.data.data;
console.log(items);
store.commit('update', items);
}
其中的update已经在mutation中定义了,因为我们知道vue中的state只能通过commit这一种方式来替换而不能通过其他方式,如下:
mutations: {
update (state, items) {
state.items = items;
}
}
最后,我们需要把items挂载到组件下:
data: function () {
return {
name: "CommodityKinds",
items: this.$store.state.items
}
},
说明:因为我已经将store注册到根组件下了,所以我们可以在组件中使用 this.$store.state来访问到state对象。
但是,这样是有问题的 --- 我们会发现,进入有items数据的页面后, 数据并没有被渲染出来,而是等到我们切换页面,再切换回来的时候才能渲染出来。
而问题就出现在了最后一步!
我们应该将store中的数据放在computed下而不是放在data下!!!!
具体解决方法如下:
import {mapState} from 'vuex'
然后:
computed: mapState({
items: state => state.items
})
这样,当store中的数据改变时, 就会直接改变了,更多例子可以看vuex官方文档,讲的很好。
总结: 一般而言,我们需要将store下的state放在computed中,将组件自身的state,不需要像vuex这样动态的、传递的放在 data 下即可。
6. 在vue中,我们可以使用v-on:click.once对click处理函数只绑定一次,这样就类似于jquery中的one绑定了。
7. 在jquery中,如果我们希望第一个元素最开始添加一个active类名,我们可以使用class绑定,其中是一个对象,对象中的属性是类的名称,值是布尔值,如果为true,则显示,否则不显示。
<template>
<div class="commodity-kind">
<div class="kind" v-bind:class="{active: index == 0}" v-on:click="getContent(item.id, $event)" v-for="item,index in items">
<span>{{item.name}}</span>
</div>
</div>
</template>
这样,一进去就是这样的状态了。
8. 当需要axios请求时,如果我们在不同的组件中都需要请求,并且都有相同的请求头,特别是最近的项目我需要使用vue-cli的express代理Tomcat服务器进行测试开发时,就要添加/api才能正常访问,但是在每一个请求前添加这个是非常麻烦的,并且在 npm run build 时,又要把这些/api去掉,这是相当麻烦的,所以我们可以单独建立一个js文件,我命名为 request.js 文件,内容如下:
import axios from 'axios'
axios.defaults.baseURL = "/api";
axios.defaults.headers.common['BBG-Key'] = "ab9ef20253-49d4-b229-3cc2383480a6"; export default axios
其中,/api是在开发过程需要代理服务器所必须的, 所以这里设置为baseURL,那么在实际请求中,就会自动添加/api, 并且在实际生产中,我们只要注释掉它就可以了。
而BBG-Key是为了安全使用的,所以为了避免每次在请求时都添加一个请求头,我们在这里直接设置为 common(公共) 的请求头。这样,在实际的每一个请求中就不需要都添加这个请求头了。
最后导出这个 axios,在其他的模块中引用。
import axios from '../assets/js/request'
axios.get('/bbg/shop/get_classify', {
params: {
sid:
}
})
.then(function (response) {
if (response.data.code == ) {
items = response.data.data;
//............
这样,就会较之前省去很多的工作量。 good!
9. vue中在css下写的,即一般使用的时作为背景图的,在assets下的图片经过打包之后使用的时base64的编码方式,所以,如果在js中操作css,使用路径的方式是行不通的,我的方式是使用base64, 但是有更好的方法吗?如下所示:
handleDefault (id,e) {
$(".default").html("设为默认").css({
'color': 'black',
'background': 'url() no-repeat',
'background-size': '0.4rem'
}); $(e.currentTarget).html("默认地址").css({
'color': '#51B1B0',
'background': 'url() no-repeat',
'background-size': '0.4rem'
});
10. class绑定的是一个对象,一般情况下,这个对象直接定义在html中是比较好处理的,如下:
<!-- 这里使用class绑定来决定默认 -->
<span class="no-default" v-bind:class="{default: item.id == defaultAddress.id}" v-on:click="handleDefault(item.id, $event)" >
{{ (item.id == defaultAddress.id) ? "默认地址" : "设为默认" }}
</span>
注意: class中的class名称不能用引号括起来。
11. 在menu中,每当点击一个选项时,替换其背景图片,如何做到实时的变化。
最开始,我的实现思路是: 先通过import的方式引入,然后在 v-for 中引用data下的每一个项目的src, 然后当点击选项的时候, 用switch函数来根据点击的index来进行替换图片,但是这样的替换存在一个问题: 每当点击之后,第一次并没变化,而是再点击一次,才会发生改变。
原因: 在vue中,data下的值和DOM中不是实时更新的,所以一般实时更新就要使用store。 即在store中import 图片资源,然后在改变的时候通过mutations进行改变。 这样的变化就是实时的了。
问题: 虽然使用 mutations 可以实时改变,但问题是,我们完全是没有必要的,因为这个改变只需要在一个组件中,使用store未免太小题大做了。
注意:这里使用的是vue的data,并且需要改变的时引入的文件(需要打包的),对于下面这样只需要修改颜色的不需要使用这样的方式, 只需要使用 zepto 来改变css即可,这样一定是实时的。
12. 使用actions时,需要commit Mutations,但是actions 不支持多参数传递,也就是说第一个参数是Mutation,第二个参数是我们需要传递的值,如果传入多个,那么第三个及以后将自动忽略,为了解决这个问题,我们可以将多个值封装到一个对象,然后传递这个对象就可以了,这就类似于Payload啊啊啊。
if (response.data.code == ) {
for (let i = ; i < response.data.data.length; i++) {
console.log(response.data.data[i], index);
var obj = {
index: index,
item: response.data.data[i]
};
commit(UPDATE_ALL_CONTENT, obj); }
index++;
resolve();
}
OK! 这就是payload。 哈哈哈哈 理解就好。
13. 在vue中,我们传入的事件一定是$event,但是获取时, e.currentTarget 和 e.target 获取的不一样的,区别在于 前者是当前的元素,即冒泡的最后一个绑定事件的元素,而后者是 最原始的元素。
关键: 后者可以实现事件代理。
14. 有时候啊, 一个很小的错误都会导致全局的失败! 比如,不知道为什么就报下面这种错误!
然后内容就显示不出来,但是通过network可以获知数据都请求到了,所以遇到这种问题我的解决方法还是寻找于此有关的代码,然后逐个注释代码,如果注释之后不再出错,就说明问题出在了这里,通过寻找,问题在这:
<template>
<div class="item"}>
即之前添加属性时, } 没有去掉。
虽然有问题了,但是解决问题的方法和思路正确就好。
15. 为什么document.body.scrollTop = 0 不生效,而 document.querySelector("body").scrollTop = 0; 是可以的呢?
16. 下面的这个错误而很明显! 就是在创建钩子函数created中出现了未定义的变量:
即 Error in created hook!
17. localStorage无法输出
为什么只有localStorage可以输出,而其他的不能呢? 就是访问不到属性!
vue中遇到的坑的更多相关文章
- vue中遇到的坑!!!!!
一 .vue安装的坑 报错时的常见问题 1.cnpm install 模块名 –save-dev(关于环境的,表现为npm run dev 启动不了)cnpm install 模块名 –save(关于 ...
- vue中的css作用域、vue中的scoped坑点
一.css作用域 之前一直很困扰css的作用域问题,即使是模块化编程下,在对应的模块的js中import css进来,这个css仍然是全局的.导致在css中需要加上对应模块的html的id/class ...
- vue中遇到的坑keep-alive、vue-router相关
在进入详情页之后,然后返回到首页,报错如下. 虽说是报错了,但是对我最后的页面并没有什么影响,但是出现了一堆红色的报错,作为一个前端工程师,看着还是十分难受的!! 一旦出现问题,我的解决思路一般是, ...
- vue中遇到的坑 --- 变化检测问题(数组相关)
最近在项目中遇到了一个问题,不知道为什么,所以最后通过动手做demo实践.查文档的方式解决了,这里做一个总结. 例1 <!DOCTYPE html> <html lang=" ...
- Vue中axios踩坑之路-POST传参
https://blog.csdn.net/call_me_fly/article/details/79012581
- Vue中应用CORS实现AJAX跨域,及它在 form data 和 request payload 的小坑处理
基本概念部分(一):理解CORS 说道Vue的跨域AJAX,我想先梳理一遍CORS跨域,"跨域资源共享"(Cross-origin resource sharing),它是一个W3 ...
- vue中使用keepAlive组件缓存遇到的坑
项目开发中在用户由分类页category进入detail需保存用户状态,查阅了Vue官网后,发现vue2.0提供了一个keep-alive组件. 上一篇讲了keep-alive的基本用法,现在说说遇到 ...
- 记录vue中一些有意思的坑
记录vue中一些有意思的坑 'message' handler took 401ms 在出现这个之前,我一直纠结于 是如何使用vue-router或者不使用它,通过类似的v-if来实现.结果却出现这个 ...
- vue中的坑 --- 锚点与查询字符串
在vue中,由于是单页面SPA,所以需要使用锚点来定位,在vue的官方文档中提到过也可以不使用锚点的情况,就是在vue-router中使用history模式,这样,在url中就不会出现丑陋的#了,但是 ...
随机推荐
- delphi xe6 调用java GPS的方法
如果用xe6自带的LocationSensor控件,默认优先使用网络位置,网络位置定位精度不准确,不能满足高精度定位的要求.但xe6自带的LocationSensor控件不能指定网络定位优先还是GPS ...
- Bat 多个执行操作选择
Bat在日常编程中使用到会帮我们省去很多力气. @echo off Title DataBase Color 0A :caozuo echo. echo ═══════════════════════ ...
- java 学习第三篇if判断
JAVA 判断 单词: if 如果 else 否则 单分支: If(条件) { 代码块 } If是一个判断语句.代码格式如上. If括号的内是表达式.如果表达式值是成立的便执行代码块.之后在执行IF语 ...
- webpack4 入门(一)
一.简介 WebPack可以看做是模块打包机:它做的事情是,分析你的项目结构,找到JavaScript模块以及其它的一些浏览器不能直接运行的拓展语言(Scss,less, TypeScript等),并 ...
- Python中logging模块的基本用法
在 PyCon 2018 上,Mario Corchero 介绍了在开发过程中如何更方便轻松地记录日志的流程. 整个演讲的内容包括: 为什么日志记录非常重要 日志记录的流程是怎样的 怎样来进行日志记录 ...
- 解密QQ号
啊哈~ ---------------------------------------------------------- http://bbs.ahalei.com/thread-4489-1-1 ...
- Apache 性能调优-参考篇
1 内存 适当选用适合大小的内存,保证谷峰负载时,有足够的内存使用 2 使用ab测试apache性能 ab -n 1000 -c 10 http://www.test.com 使用ab的缺点: ...
- 网络通讯与IP地址
1.主机:Host,台式机,笔记本,手机等设备 2.网络介质:网线,光纤,无线网Wi-Fi.移动网络 3.数据:一串子节 网络通讯的检测:安装wireshark,通常称为抓包工具 抓,capture ...
- C++学习笔记-关键词
1.friend友元 采用类的机制后实现了数据的隐藏与封装,类的数据成员一般定义为私有成员,成员函数一般定义为公有的,依此提供类与外界间的通信接口.但是,有时需要定义一些函数,这些函数不是类的一部分( ...
- kuangbin专题十六 KMP&&扩展KMP HDU2594 Simpsons’ Hidden Talents
Homer: Marge, I just figured out a way to discover some of the talents we weren’t aware we had. Marg ...