Vue(小案例_vue+axios仿手机app)_图文列表实现
一、前言
1、导航滑动实现
2、渲染列表信息时让一开始加载的时候就请求数据
3、根据路由的改变,加载图文的改变(实现用户访问网站时可能执行的三个操作)
二、主要内容
1、导航滑动实现:
(1)演示效果:

(2)代码实现
<!--导航栏用ul li实现-->
<ul>
<li v-for='(item,index) in categoryList' :key='index'>
<a href="javascript:;">{{item.title}}</a>
</li> </ul>
</div> <style> li {
list-style: none;
display: inline-block;
margin-left: 10px;
height: 30px;
} ul {
/*强制不换行*/
white-space: nowrap;
overflow-x: auto;
padding-left: 0px;
margin: 5;
} </style>
2、渲染列表信息时让一开始加载的时候就请求数据
(1)在methods里面封装一个请求的方法
export default{
name:'PhotoList',
data(){
return{
categoryList,
title_h:'图文分享'
}
},
methods:{
loadImageByCategoryId(id){ //这里传入请求的id
this.$axios.get('api/index?type=top&key=79b64827a7a0f95504dfb2f7e903208d'+id)
.then(res=>{
console.log(res.data.result.data)
})
.catch(err=>{
console.log('数据获取失败',err);
})
}
}
}
(2)在created()中最开始就调用这个方法
created(){
this.loadImageByCategoryId(0);//0表示所有的数据
this.$axios.get('api/index?type=top&key=79b64827a7a0f95504dfb2f7e903208d')
.then(res=>{
console.log(res.data.result.data)
})
.catch(err=>{
console.log('新闻数据获取失败',err)
})
}
(3)当图片过多的时候需要设置图片懒加载(n+1)模式,这里用mint-ui里面的v-lazy
//Mint-ui里面的图片懒加载
<img v-lazy='item.img_url'>
3、根据路由的改变,加载图文的改变(牵涉到动态路由的匹配:https://router.vuejs.org/zh/guide/essentials/dynamic-matching.html#响应路由参数的变化)
官网上明确告诉我们:当路由从/user/foo 导航到 /user/bar, 原来的组件实例会被复用。因为两个路由都渲染同一个组件,比起销毁再创建,复用显得更加高效。不过,这意味着组件的生命周期钩子不会再被调用。复用组件时,如果想对不同的路由参数做出不同的响应的时候,此时可以用1)watch监听 2)使用beforeRouteUpdate导航守卫
操作一:在当前网站中,直接在url输入动态路由
(1)下面用beforeRouteUpdate(to, from, next){ }来实现
methods:{
loadImageByCategoryId(id){ //这里传入请求的id
this.$axios.get('api/index?type=top&key=79b64827a7a0f95504dfb2f7e903208d')
.then(res=>{
console.log(res.data.result.data)
})
.catch(err=>{
console.log('数据获取失败',err);
})
}
},
created(){
//api/index?type=top&key=79b64827a7a0f95504dfb2f7e903208d
this.loadImageByCategoryId(0);//0表示所有的数据
this.$axios.get('api/index?type=top&key=79b64827a7a0f95504dfb2f7e903208d')
.then(res=>{
console.log(res.data.result.data)
})
.catch(err=>{
console.log('新闻数据获取失败',err)
})
},
beforeRouteUpdate(to, from, next){
//在当前路由改变,但是该组价被复用时调用
//举例来说,对于一个带有动态参数的路径/foo/:id 在/foo/1 和 /foo/2之间跳转的时候
//由于会渲染同样的Foo组件,因此组件实例会被复用。这个钩子在这个时候就会被调用
console.log(to);//to是目的
this.loadImageByCategoryId(to.params.categoryId); //拿到里面的路由参数调用上面封装的请求方法,就会根据不同的参数请求到不同类型的数据
}
}
操作二:很多时候通过点击上面的滑动导航改变路由
(1)给每个导航li标签注册点击事件,然后将当前的id传进去
<div class="photo-header">
<ul>
<li v-for='(category,index) in categoryList' :key='index' @click='categoryHandler(category.id)'>
<router-link :to="category.routerName" exact @click.native ='changeHash()'>{{item.title}}</router-link> </li> </ul>
</div>
(2)在method中定义这个categoryHandler点击事件,
categoryHandler(id){
this.$router.push({name:'photo.list'}, params:{categoryId:id}) //当用户点击之后就会跳转到这个路由,然后再执行beforeRouterUpdate方法
},
(3)执行beforeRouteUpdate方法,重新根据不同路由参数请求数据
beforeRouteUpdate(to, from, next){
//在当前路由改变,但是该组价被复用时调用
//举例来说,对于一个带有动态参数的路径/foo/:id 在/foo/1 和 /foo/2之间跳转的时候
//由于会渲染同样的Foo组件,因此组件实例会被复用。这个钩子在这个时候就会被调用
console.log(to);//to是目的
this.loadImageByCategoryId(to.params.categoryId); //拿到里面的路由参数调用上面封装的请求方法,就会根据不同的数据请求到不同类型的数据
}
操作三:用户可能关闭了当前的网站,然后从浏览器另一个网页中直接拿这个路由来刷新(这个时候路由没有更新)
(1)用beforeRouteEnter
beforeRouteEnter(to, from, next){
//在渲染该组件的对应路由被confirm前调用
//不能获取组件实例this
//因为当守卫执行前,组件实例还没有被创建
next(vm =>{
vm.loadImageByCategoryId(to.params.categoryId)
})
},
结合以上三个操作就可以实现,通过点击不同导航li标签,渲染不同类型的数据, 可以通过在当前网站上输入不同的动态路由参数,渲染不同的数据,还可以从别的网站进来,渲染不同的数据
三、总结
结合以上三个操作就可以实现,通过点击不同导航li标签,渲染不同类型的数据, 可以通过在当前网站上输入不同的动态路由参数,渲染不同的数据,还可以从别的网站进来,渲染不同的数据
Vue(小案例_vue+axios仿手机app)_图文列表实现的更多相关文章
- Vue(小案例_vue+axios仿手机app)_图片列表操作
一.前言 1.让图片还没有被完全加载出来的时候给用户提示 2.图片查看器 二.主要内容 1.让图片还没有被完全加载出来的时候 ...
- Vue(小案例_vue+axios仿手机app)_购物车(二模拟淘宝购物车页面,点击加减做出相应变化)
一.前言 在上篇购物车中,如果用户刷新了当前的页面,底部导航中的数据又会恢复为原来的: 1.解决刷新,购物车上数值不变 ...
- Vue(小案例_vue+axios仿手机app)_购物车
一.前言 1.购物车 二.主要内容 1.效果演示如下,当我们选择商品数量改变的时候,也要让购物车里面的数据改变 2.具体实现 (1)小球从上面跳到下面的效果 (2)当点击上面的“加入购物车按钮”让小球 ...
- Vue(小案例_vue+axios仿手机app)_公共组件(路由组件传参)
一.前言 1.公共轮播图的实现 2.组件传参,公共组件的实现 二.主要内容 1.公共轮播图的实现 (1)分析:当渲染不同的轮 ...
- Vue(小案例_vue+axios仿手机app)_上拉加载
---恢复内容开始--- 一.前言 ...
- Vue(小案例_vue+axios仿手机app)_实现用户评论
一.前言 1.渲染评论列表 2.点击加载按钮,加载更多 3.提交评论 二.主要内容 1.评论列表一般是注册到一个全局的公共组件中 2.请求后台数据,渲染评论列表 (1)数据格式如下 地址 /ap ...
- Vue(小案例_vue+axios仿手机app)_首页(底部导航栏+轮播图+九宫格)
---恢复内容开始--- 一.前言 1.底部导航(两种做法) 2.轮播图 ...
- Vue(小案例_vue+axios仿手机app)_购物车(计算商品总金额)
一.前言 1.计算总金额 2.点击删除按钮,删除对应的商品信息 3.当还没结算的时候,当用户跳到其他页面 ...
- Vue(小案例_vue+axios仿手机app)_Vuex优化购物车功能
一.前言 1.用vuex实现加入购物车操作 2.购物车详情页面 3.点击删除按钮,删除购物详情页面里的对应商品 二.主要内容 1.用vuex加入购物车 (1)在src ...
随机推荐
- ASP.NET Zero--开发指南
ASP.NET Zero--开发指南(Lyhcee 译) 01. 前期介绍 02. 前期要求 03. 解决方案结构(层) 04. 前端应用程序 05. 后端应用程序 06.WEB.HOST应用程序 0 ...
- Spring MVC 响应视图(六)
完整的项目案例: springmvc.zip 目录 实例 除了依赖spring-webmvc还需要依赖jackson-databind(用于转换json数据格式) <dependency> ...
- 高德地图 Service 创建服务 USERKEY_PLAT_NOMATCH
在使用高的地图 创建服务的时候 { "errmsg": "USERKEY_PLAT_NOMATCH", "errcode": 10009, ...
- js 学习之路7:switch/case语句的使用
语法格式: switch(n) { case 1: 执行代码块 1 break; case 2: 执行代码块 2 break; default: n 与 case 1 和 case 2 不同时执行的代 ...
- 6.2Python数据处理篇之pandas学习系列(二)Series数据类型
目录 目录 (一)Series的组成 (二)Series的创建 1.从标量中创建Series数据 2.从列表中创建Series数据 3.从字典中创建Series数据 4.从ndarry中创建Serie ...
- .NET CORE学习笔记系列(2)——依赖注入【1】控制反转IOC
原文:https://www.cnblogs.com/artech/p/net-core-di-01.html 一.流程控制的反转 IoC的全名Inverse of Control,翻译成中文就是“控 ...
- Python开发【第一篇】基础题目二
1 列表题 l1 = [11, 22, 33] l2 = [22, 33, 44] # a. 获取l1 中有,l2中没有的元素 for i in l1: if i not in l2: # b. 获取 ...
- 0106笔记--vc2012 打印堆栈
清空icound 菜单 调试-->选项和设置--->常规--->启用调试助手 要把在未经处理的异常上展开调用堆栈选中: 然后就有
- 23 python初学(模块和包)
模块(module): 好处: 提高代码可维护性 + 编写代码不必从零开始 模块有三种: python标准库.第三方模块.应用程序自定义模块 另外,使用模块还可以避免函数名和变量名冲突,相同名字的函数 ...
- AI AutoML
AutoML 参考链接: https://arxiv.org/pdf/1810.13306.pdf http://nooverfit.com/wp/7%E4%B8%AA%E4%BD%A0%E5%8F% ...