《vue.js2.0从入门到放弃》学习之路
原文地址:
Vue.js2.0从入门到放弃---入门实例(一):http://blog.csdn.net/u013182762/article/details/53021374
Vue.js2.0从入门到放弃---入门实例(二):http://blog.csdn.net/u013182762/article/details/53027883
Vue.js2.0从入门到放弃---入门实例(三):http://blog.csdn.net/u013182762/article/details/53488870
有幸看到作者的这3篇从入门到放弃,带我真正开始了vue.js的旅程,看完了这3篇文章,坑也踩了不少,不过还好,最后还是完美落幕,把详情页也补充进来了。
因为我是有安装eslint的,所以对代码的格式要求很高,哪怕一个空格都不会放过,作者在入门实例(三)里面有提到,按照他的代码是会报很多错误的,不过我已经把错误都解决的了,简单罗列几个,如果还有别的error可以一起解决~
在main.js文件里面,new实例前面要加上这2句注释。
/* eslint-disable no-new */ /* eslint-disable no-unused-vars */ new Vue({ el: '#app', data () { return { transitionName: 'slide' } }, router, watch: { '$route' (to, from) { const toDepth = to.path.substring(0, to.path.length - 2).split('/').length const fromDepth = from.path.substring(0, from.path.length - 2).split('/').length this.transitionName = toDepth < fromDepth ? 'slide_back' : 'slide' } } })
home.vue文件里面的list标签,有for循环,所以要加上key值
<div class="content">
<ul class="cont_ul">
<list v-for="(item, index) in items" :price="item.price" :title="item.title" :img="item.img" :key="item.id" :index="index"></list>
</ul>
</div>
详情页主要是要拿到li里面的内容,那就必须拿到li的index,所以在home.vue里面循环的时候要把index定义出来,上面代码已经有了。我的处理方法是把跳转的地址加上index作为参数,再通过拿到这个参数,来决定详情页显示什么。一开始我以为用
this.$route.query拿到是就是个数值,没想到这样拿到的居然是个对象,就只能再处理一遍了。details是我自己在json文件里面加的值,用于显示详情的,可以自由更改。以下是Detail.vue里面的代码,css没变,我就不再重复:
<template>
<div class="detail">
<detail-header></detail-header>
<img :src=imgSrc alt="">
<p>{{details}}</p>
</div>
</template>
<script>
import DetailHeader from '../components/DetailHeader'
export default {
data () {
return {
imgSrc: '',
details: ''
}
},
components: {
DetailHeader
},
created () {
this.fetchData()
},
methods: {
fetchData () {
this.$http.get('/api/books')
.then(res => {
var i = this.$route.query
var result = res.data
for (var key in i) {
this.imgSrc = result.data[key].img
this.details = result.data[key].details
}
}, error => {
console.log(error)
})
}
}
}
</script>
DetailHeader.vue的代码:
<template>
<header class="header">
<div class="header_inner flexWrap">
<div id="header_btn_nav" class="header_btn header_btn_back" v-on:click="goBack">返回</div>
<div class="header_cont flex">{{title}}</div>
<div class="header_btn header_btn_cart"></div>
</div>
</header>
</template>
<script>
import List from '../components/List'
export default {
data () {
return {
title: ''
}
},
methods: {
goBack () {
window.history.back()
},
fetchData () {
this.$http.get('/api/books')
.then(res => {
var i = this.$route.query
var result = res.data
for (var key in i) {
this.title = result.data[key].title
}
}, error => {
console.log(error)
})
}
},
components: {
List
},
created () {
this.fetchData()
}
}
</script>
这detail的文件里面有重复的脚本,我想应该还是可以再优化的,目前水平还不够,只是能实现功能,要是有大神指导请多多赐教。
自身不足:
组件之间的通信
函数与html之间的联系
数据的请求

浙公网安备 33010602011771号