时间:2021-05-26
回顾新闻详细页
很早我们的新闻详情页是在news-detail.vue 组件里,获取服务器数据,然后把数据保持到组件的data 里,既然我们已经用到了vuex,学习了它的state,我们就应该想到把返回的数据交给state 来存储。
1.首先在Vuex.Store 实例化的时候:
state:{ user_name:"", newslist:[], newsdetail:{} },增加一个newsdetail 对象,newslist 数组是我们前面用来保存新闻列表数据的。
2.下面就要看在news-detail.vue 组件里,怎么请求数据,然后交给newsdatail :
<script> export default{ // 创建的时候[生命周期里] created(){ this.$http.get("http://localhost/newsdetail.php?id="+this.$route.params.newsid).then(function(res){ this.$store.state.newsdetail = res.body; },function(res){ // 处理请求失败 }); }, }</script>通过this.$store.state.newsdetail = res.body; 就把服务器返回的新闻详细数据保存起来了。
3.那么模板上怎么展示?
<div class="page-header"> <h2>{{this.$store.state.newsdetail.title}}<small>{{this.$store.state.newsdetail.pubtime}}</small></h2> <p>点赞数:{{this.$store.state.newsdetail.agree}} <button class="btn btn-success">点赞</button></p> <p>{{this.$store.state.newsdetail.desc}}</p></div>这里我们要来实现一个点赞功能
点击“点赞”按钮,就更改点击数。
其实就是更改newsdetail 里的agree 属性。
本文参考文档:https://vuefe.cn/vuex/actions.html
import Vuex from 'vuex';Vue.use(Vuex);const vuex_store = new Vuex.Store({ state:{ user_name:"", newslist:[], newsdetail:{} }, mutations:{ showUserName(state){ alert(state.user_name); }, setAgree(state,agreeNum){ state.newsdetail.agree = agreeNum; } }, actions:{ agree(context,newsid){ // 进行请求,获取点赞后的agree字段属性值 Vue.http.post("http://localhost/agree.php",{newsid:newsid},{emulateJSON:true}).then(function (res) { // 处理业务 // 调用上面setAgree方法更新点赞数 context.commit("setAgree",res.body.agree); },function(){}) } }, getters:{ getNews(state){ return state.newslist.filter(function (news) { return !news.isdeleted; }) } }})在actions 里定义了一个方法agree 发送网络请求,获取最新的点赞数。
同时mutations 里定义了一个setAgree 方法,用来同步页面上的点赞数。
agree(context,newsid){ // 进行请求,获取点赞后的agree字段属性值 Vue.http.post("http://localhost/agree.php",{newsid:newsid},{emulateJSON:true}).then(function (res) { // 处理业务 // 调用上面setAgree方法更新点赞数 context.commit("setAgree",res.body.agree); },function(){}) }重点说明:这里发送http请求,和组件里不一样,需要注意。
那么,组件里怎么调用这里的agree 方法呢?
<button class="btn btn-success" @click="submitAgree">点赞</button> methods:{ submitAgree(){ // 组件了调用actions里定义的agree方法 this.$store.dispatch("agree",this.$store.state.newsdetail.id) } }news-detail.vue 组件全部代码:
<template> <div class="news-detail"> <div class="row"> <div class="page-header"> <h2>{{this.$store.state.newsdetail.title}}<small>{{this.$store.state.newsdetail.pubtime}}</small></h2> <p>点赞数:{{this.$store.state.newsdetail.agree}} <button class="btn btn-success" @click="submitAgree">点赞</button></p> <p>{{this.$store.state.newsdetail.desc}}</p> </div> </div> </div></template> <script> export default{ // 创建的时候[生命周期里] created(){ this.$http.get("http://localhost/newsdetail.php?id="+this.$route.params.newsid).then(function(res){ this.$store.state.newsdetail = res.body; },function(res){ // 处理请求失败 }); }, methods:{ submitAgree(){ // 组件了调用actions里定义的agree方法 this.$store.dispatch("agree",this.$store.state.newsdetail.id) } } }</script>后端程序增加点赞数,这里就不赘述了。只需返回一个json对象:
{"status":"success","agree":100}以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
软文投放应该联系当地媒体,比如以前合作过的媒体,或者利用公司现有的新闻点来邀请记者采访,或者制造一些新闻点,给媒体发新闻。当然具体那些新闻点,那些媒体,根据公司
Vue+Bootstrap收藏(点赞)功能逻辑与具体实现(原创),供大家参考,具体内容如下点赞功能逻辑点赞功能说明:连接了数据库,在有登录功能的基础上。点赞功能
我用Vue.js实现微信朋友圈的一些功能,实现展示朋友圈,评论,点赞。先构造一个vue的实例,对会更改的数据进行双向绑定,我用JSON伪造模版数据,先实现显示朋
网站编辑要具备良好的新闻选择能力。首先,网站编辑要善于从各大新闻网站,实现新闻重组,并针对舆论导向,编辑新闻点,让新闻紧扣时代背景,更好地强化新闻的传播力;其次
利用模拟操作的方式实现QQ全自动点赞此功能需要加载精易模块.版本2.支持库iext.支持库HtmlView.支持库spec.程序集窗口程序集1.程序集变量停止变