八、VueJs 填坑日记之参数传递及内容页面的开发
-
资源ID:44169614
资源大小:464.84KB
全文页数:5页
- 资源格式: DOCX
下载积分:0金贝
快捷下载
账号登录下载
微信登录下载
微信扫一扫登录
1、金锄头文库是“C2C”交易模式,即卖家上传的文档直接由买家下载,本站只是中间服务平台,本站所有文档下载所得的收益全部归上传人(卖家)所有,作为网络服务商,若您的权利被侵害请及时联系右侧客服;
2、如你看到网页展示的文档有jinchutou.com水印,是因预览和防盗链等技术需要对部份页面进行转换压缩成图而已,我们并不对上传的文档进行任何编辑或修改,文档下载后都不会有jinchutou.com水印标识,下载后原文更清晰;
3、所有的PPT和DOC文档都被视为“模板”,允许上传人保留章节、目录结构的情况下删减部份的内容;下载前须认真查看,确认无误后再购买;
4、文档大部份都是可以预览的,金锄头文库作为内容存储提供商,无法对各卖家所售文档的真实性、完整性、准确性以及专业性等问题提供审核和保证,请慎重购买;
5、文档的总页数、文档格式和文档大小以系统显示为准(内容中显示的页数不一定正确),网站客服只以系统显示的页数、文件格式、文档大小作为仲裁依据;
6、如果您还有什么不清楚的或需要我们协助,可以点击右侧栏的客服。
|
下载须知 | 常见问题汇总
|
八、VueJs 填坑日记之参数传递及内容页面的开发
我们在上一篇博文中,渲染出来了一个列表,并在列表中使用了router-link标签,标签内的:to就是链接地址,昨天咱们是这样写的,今天我们来完成内容页面的渲染。编编写内容写内容页页面面还是废话少说,先上代码,将以下代码保存到/src/pages/Content.vue中:作者:dat.author.loginname 发表于:$utils.goodTime(dat.create_at)网友回复:评论者:i.author.loginname 评论于:$utils.goodTime(i.create_at)import myHeader from './components/header.vue'import myFooter from './components/footer.vue'export default components: myHeader, myFooter ,data () return id: this.$route.params.id,dat: ,created () this.getData(),methods: getData () this.$api.get('topic/' + this.id, null, r => this.dat = r.data)然后我们在上一章的列表中随便点击一篇文章查看到以下界面:关于样式的东西,咱们后期集成amaze ui的时候再来实现,暂时只实现功能。重点分析重点分析其他的内容,我们在列表页面已经见过了。这里第一次出现 这个东西。同样是渲染内容, v-html 和 v-text 有什么区别呢?其实区别非常简单,v-text 会把所有的内容当成字符串给直接输出出来。而 v-html 会把字符串给转换为 html 标记语言给渲染出来。更多关于vue的指令内容请参见:https:/cn.vuejs.org/v2/api/#v-html注意: 我们在列表中,我们使用的是 Header 注意的组件命名方式,为什么我这边用了 myHeader 注意的组件命名方式呢?其实,我想说明的是,我们不要使用 html 本身就支持的标签名称来自定义我们的组件,这容易导致混乱,最好,是像内容页里面这样,使用自定义的标签名。(先前忘记了,现在强调一下。大家可以对之前的代码进行修改。)script 部分部分代码基本上是一致的,重点是 id: this.$route.params.id, 这一句。还记得我们先前是怎么配置路由的吗?忘记了不要紧,再回顾一下,/src/router/index.js里是这样写的:import Vue from 'vue'import Router from 'vue-router'import Index from '/pages/Index'import Content from '/pages/Content'Vue.use(Router)export default new Router(routes: path: '/',component: Index,path: '/Content/:id',component: Content)看重点:path: '/Content/:id', 中,我们使用了 :id 这个东西。这是动态路由匹配。我们需要从我们的 url 中,来获取我们的 id 然后根据这个 id 来进行数据的查询。那么我们已经在 url 包含了这个 id 了。http:/localhost:8080/#/Content/5a11132da6731ee928cc6bbc如上:5a11132da6731ee928cc6bbc这个就是 ID ,奇怪是奇怪了点,但确实就是 id。如何获取id参数,不用多想,vuerouter 早就给我们准备了解决方法。我们可以在项目中打印,可以看到下图红框圈住的就是router对象:console.log(this.$route)我们再看下我们的接口数据调用,代码如下:getData () this.$api.get('topic/' + this.id, null, r => this.dat = r.data)等于没什么要说的,就是把数据拿过来了而已,需要注意的是,我们的请求的接口地址是根据 id 进行变化的。所以,我这边采用了字符串拼接的方法,'topic/' + this.id 来得到我们真正想要请求的接口数据。错误处错误处理理在上面图中,我们发现出了一个错误,意思是说不能读取名为loginname的属性,因为没有定义,那我们console.log(r.data)的时候,会发现loginname确实给我们返回了。那这是为什么呢?其实也没有大不了的,这个意思是说初始的时候我们data里的dat: 是空,确实是没有author.loginname属性存在。那怎么解决呢?很简单,看代码:data () return id: this.$route.params.id,dat: author:loginname:“,既然说没有定义,那我们定义上就OK了。到此参数传递和内容页面已经开发完成,大家有疑问可以在评论里留言。也可以加入我拉QQ群。忠心感谢FungLeo,是你们无私的奉献,才让我们有了学习的参考,以下是地址:http:/blog.csdn.net/fungleo/article/details/77575077