摘要:上一篇文章中我們已經(jīng)實現(xiàn)了評論的發(fā)布功能,現(xiàn)在要實現(xiàn)回復(fù)評論的功能,,首先呢,要知道你回復(fù)的是哪一條評論,所以我們這里要或得評論的,當(dāng)點擊評論的時候?qū)崿F(xiàn)評論的回復(fù),這里用到,把該方法放到中,這里叫做,然后在里面的里面定義一個參數(shù),把賦給的值
上一篇文章中我們已經(jīng)實現(xiàn)了評論的發(fā)布功能,現(xiàn)在要實現(xiàn)回復(fù)評論的功能,,首先呢,要知道你回復(fù)的是哪一條評論,所以我們這里要或得評論的id,當(dāng)點擊評論的時候?qū)崿F(xiàn)評論的回復(fù),這里用到@click="reply(item)",把該方法放到methods中,這里叫做item.id,然后在new vue里面的data里面定義一個參數(shù),把item.id賦給comment_id,comment_id的值一開始為空,然后在UIChatBox.open里的ret函數(shù)參數(shù)里面調(diào)用comment_id: vm.comment_id
data:{ comment_id: null } methods: { reply: function (item) { this.comment_id = item.id } }
這里已經(jīng)獲取了comment_id的值,當(dāng)回復(fù)時應(yīng)該讓手機(jī)默認(rèn)鍵盤彈出,輸入框或得焦點,,這里用到了UIChatBox.popupKeyboard();然后當(dāng)你回復(fù)時,一般常見的會有回復(fù):“某某”的評論或者“@”發(fā)表評論人的評論,所以呢,這里要或得發(fā)表評論的用戶信息,,在data里面設(shè)置一個user額變量,再將item的用戶id賦給user,所以綜上所述,代碼如下
data:{ user: JSON.parse(localStorage.getItem("user")), comment_id: null, comments: [] }, methods: { reply: function (item) { this.comment_id = item.id UIChatBox.popupKeyboard(); UIChatBox.value({ msg: "@" + item.user.username + " " }); //設(shè)置輸入框的值 } }
到這里,我們回復(fù)的功能就已經(jīng)基本實現(xiàn)了,以下是完整代碼
htmljs apiready = function(){ var id=api.pageParam.id; var UIChatBox = api.require("UIChatBox"); var vm=new Vue({ el:"#app", data:{ user: JSON.parse(localStorage.getItem("user")), comment_id: null, comments: [] }, methods: { reply: function (item) { this.comment_id = item.id UIChatBox.popupKeyboard(); UIChatBox.value({ msg: "@" + item.user.username + " " }); } }, created:function(){ var that=this; app.get("news/"+id + "/comments",function(data){ that.comments=data.data; // console.log(data) },function(err){ }) } }); // app.alert(localStorage.getItem("token")) UIChatBox.open({ style:{ indicator:{ target:"both" } } }, function(ret, err) { if (ret) { if (ret.eventType == "send") { //post到服務(wù)端接口 app.post("news/" + id + "/comments", { comment_id: vm.comment_id, content: ret.msg }, function (data) { vm.comments.push(data) api.toast({ msg: "發(fā)送成功" }); UIChatBox.closeKeyboard(); vm.comment_id = null }, function (xhr) { switch (xhr.status) { case 422: api.toast({ msg: xhr.responseJSON.content[0] }); break; } }) } } else { alert(JSON.stringify(err)); } }); };
補(bǔ)充說明,當(dāng)我們回復(fù)別人的評論時,別人發(fā)表的評論用戶頭像在左邊,本人發(fā)布的回復(fù)或者評論頭像在右邊,這里有點像qq、微信的聊天界面,大家可以想象以下,,所以這里我們要判斷以下讓列表中的頭像靠左或靠右,如果評論item.user_id 等于user.id時,說明是作者本人發(fā)布,在這里就出現(xiàn)了以下代碼
:class="item.user_id == user.id ? "aui-pull-right" : """
當(dāng)符合item.user_id == user.id時添加aui框架中的aui-pull-right樣式,否則不添加。
文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請注明本文地址:http://systransis.cn/yun/81948.html
摘要:關(guān)于作者程序開發(fā)人員,不拘泥于語言與技術(shù),目前主要從事和前端開發(fā),使用和,端使用混合式開發(fā)。個人網(wǎng)站最近剛寫了一個手機(jī)在線播放的電影站開發(fā)混合式系列第集技術(shù)選型是一套簡潔優(yōu)雅的開發(fā)框架。 關(guān)于作者 程序開發(fā)人員,不拘泥于語言與技術(shù),目前主要從事PHP和前端開發(fā),使用Laravel和VueJs,App端使用Apicloud混合式開發(fā)。合適和夠用是最完美的追求。 個人網(wǎng)站:http://...
摘要:關(guān)于作者程序開發(fā)人員,不拘泥于語言與技術(shù),目前主要從事和前端開發(fā),使用和,端使用混合式開發(fā)。個人網(wǎng)站最近剛寫了一個手機(jī)在線播放的電影站開發(fā)混合式系列第集技術(shù)選型是一套簡潔優(yōu)雅的開發(fā)框架。 關(guān)于作者 程序開發(fā)人員,不拘泥于語言與技術(shù),目前主要從事PHP和前端開發(fā),使用Laravel和VueJs,App端使用Apicloud混合式開發(fā)。合適和夠用是最完美的追求。 個人網(wǎng)站:http://...
摘要:以上就是對評論模塊的設(shè)計與功能實現(xiàn),歡迎各位大佬提出代碼優(yōu)化建議,共同成長代碼出自開源項目,致力于打造全平臺型全棧精品開源項目。 評論模塊在很多系統(tǒng)中都有,CodeRiver河碼 作為類似程序員客棧的溝通協(xié)作平臺自然也不會少。 前端界面是參考了簡書的評論模塊,專門寫了一篇文章介紹實現(xiàn)步驟: vue + element-ui + scss 仿簡書評論模塊 感興趣的可以看看。 項目地...
摘要:所以,我們運(yùn)用這個函數(shù),也可以理解為將異步的代碼轉(zhuǎn)換為同步執(zhí)行更簡單的說就是,上面的代碼執(zhí)行完之后,里面的代碼才能運(yùn)行,以下是代碼 這段時間再用apicloud的混合開發(fā),其中在運(yùn)用swiper插件這一塊遇到了一些問題,多虧了我們老大經(jīng)驗豐富,讓我們這些后輩少采一些坑,,在這里做一下總結(jié),主要是Vue.nextTick()函數(shù)的用法 坑:當(dāng)時在運(yùn)用swiper插件的時候,沒用用vue進(jìn)...
閱讀 1967·2021-11-22 15:29
閱讀 3266·2021-10-14 09:43
閱讀 1231·2021-10-08 10:22
閱讀 3354·2021-08-30 09:46
閱讀 1441·2019-08-30 15:55
閱讀 1936·2019-08-30 15:44
閱讀 859·2019-08-30 14:19
閱讀 1453·2019-08-30 13:13
{{item.user.username}} 角色 {{item.id}}
{{item.user.created_at}}