一、前言

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)_图文列表实现的更多相关文章

  1. Vue(小案例_vue+axios仿手机app)_图片列表操作

    一.前言 1.让图片还没有被完全加载出来的时候给用户提示                                       2.图片查看器 二.主要内容 1.让图片还没有被完全加载出来的时候 ...

  2. Vue(小案例_vue+axios仿手机app)_购物车(二模拟淘宝购物车页面,点击加减做出相应变化)

    一.前言 在上篇购物车中,如果用户刷新了当前的页面,底部导航中的数据又会恢复为原来的: 1.解决刷新,购物车上数值不变                                         ...

  3. Vue(小案例_vue+axios仿手机app)_购物车

    一.前言 1.购物车 二.主要内容 1.效果演示如下,当我们选择商品数量改变的时候,也要让购物车里面的数据改变 2.具体实现 (1)小球从上面跳到下面的效果 (2)当点击上面的“加入购物车按钮”让小球 ...

  4. Vue(小案例_vue+axios仿手机app)_公共组件(路由组件传参)

    一.前言                    1.公共轮播图的实现                    2.组件传参,公共组件的实现 二.主要内容 1.公共轮播图的实现 (1)分析:当渲染不同的轮 ...

  5. Vue(小案例_vue+axios仿手机app)_上拉加载

    ---恢复内容开始--- 一.前言                                                                                    ...

  6. Vue(小案例_vue+axios仿手机app)_实现用户评论

    一.前言 1.渲染评论列表 2.点击加载按钮,加载更多    3.提交评论 二.主要内容 1.评论列表一般是注册到一个全局的公共组件中 2.请求后台数据,渲染评论列表 (1)数据格式如下 地址 /ap ...

  7. Vue(小案例_vue+axios仿手机app)_首页(底部导航栏+轮播图+九宫格)

    ---恢复内容开始--- 一.前言                        1.底部导航(两种做法)                                         2.轮播图 ...

  8. Vue(小案例_vue+axios仿手机app)_购物车(计算商品总金额)

    一.前言                 1.计算总金额                 2.点击删除按钮,删除对应的商品信息                 3.当还没结算的时候,当用户跳到其他页面 ...

  9. Vue(小案例_vue+axios仿手机app)_Vuex优化购物车功能

    一.前言         1.用vuex实现加入购物车操作 2.购物车详情页面          3.点击删除按钮,删除购物详情页面里的对应商品 二.主要内容 1.用vuex加入购物车 (1)在src ...

随机推荐

  1. Nginx+uWSGI启动Django

    在之前的几篇博客中对Django的功能做了初步实践,这里链接贴一下: Django的安装和启动 Django之--网页展示Hello World! Django之--通过MVC架构的html模板展示H ...

  2. MySQL的Limit详解

    问题:数据库查询语句,如何只返回一部分数据? Top子句 TOP 子句用于规定要返回的记录的数目.对于拥有数千条记录的大型表来说,TOP 子句是非常有用的. 在SQL Server数据库中语法为: S ...

  3. jQuery中toggle与slideToggle以及fadeToggle之间的不同

    toggle()方法: 定义和用法 切换元素的可见状态.如果被选元素可见,则隐藏这些元素,如果被选元素隐藏,则显示这些元素. 语法: $(selector).toggle(speed,callback ...

  4. Java开发学习心得(二):Mybatis和Url路由

    目录 Java开发学习心得(二):Mybatis和Url路由 1.3 Mybatis 2 URL路由 2.1 @RequestMapping 2.2 @PathVariable 2.3 不同的请求类型 ...

  5. logging_modules

    老师的博客:http://www.cnblogs.com/Eva-J/articles/7228075.html#_label13 basicconfig import logging logging ...

  6. centos下 telnet访问百度

    先在命令行输入以下命令: telnet www.baidu.com 80 点击确认之后出现如下界面 然后接着输入以下两行命令 GET /index.html HTTP/1.1 Host: www.ba ...

  7. (十一)Updating Documents

    In addition to being able to index and replace documents, we can also update documents. Note though ...

  8. Jenkins持续集成实践之java项目自动化部署

    关于Linux安装Jenkins可以参考我的这篇博文Ubuntu16.04环境安装jenkins 1.安装部署插件 进入插件管理,并搜索该插件Deploy to container Plugin进行安 ...

  9. Hive中知识点

    hive的最新学习资料:http://www.cnblogs.com/qingyunzong/p/8707885.html hive的参数设置大全:https://cwiki.apache.org/c ...

  10. Python调用接口的几种方式

    1. requests import requests, jsongithub_url = 'https://api.github.com/user/repos'data = json.dumps({ ...