溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

Vue如何實現(xiàn)發(fā)表評論功能

發(fā)布時間:2021-10-29 13:03:14 來源:億速云 閱讀:609 作者:小新 欄目:開發(fā)技術

這篇文章主要為大家展示了“Vue如何實現(xiàn)發(fā)表評論功能”,內(nèi)容簡而易懂,條理清晰,希望能夠幫助大家解決疑惑,下面讓小編帶領大家一起研究并學習一下“Vue如何實現(xiàn)發(fā)表評論功能”這篇文章吧。

具體內(nèi)容如下

1、這是我在學習中的實例,有些的不足的地方,還望各位大佬指點,感謝哦~

2、發(fā)表評論的效果圖

Vue如何實現(xiàn)發(fā)表評論功能

 點擊“發(fā)表”之后的效果(每條評論之后點擊“刪除”可以刪掉這一整條評論~)

Vue如何實現(xiàn)發(fā)表評論功能

3、完整代碼展示(我html結構寫的比較亂,這里提醒大家一下,沒有定義類的div是可以刪掉的,我是因為方便寫樣式所以多加了div)

還是要提醒一下,不要忘記引入vue.js,目錄記得根據(jù)自己存放的位置改

<!DOCTYPE html>
<html>
 <head>
  <meta charset="utf-8">
  <title></title>
  <script src="./vue.js"></script>
  <style type="text/css">
   *{
    margin: 0;padding: 0;
    box-sizing: border-box;
   }
   #app{
    width: 700px;
    height: 650px;
    margin: auto;
    border: 1px solid #ccc;
   }
   #app h2{
    width: 700px;
    font-weight: 400;
    line-height: 100px;
    padding-left: 20px;
    background-color: #cccccc;
    margin-bottom: 20px;
   }
   #app>div{
    padding: 0 20px;
   }
   #app>div>input{
    width: 200px;
    height: 30px;
    padding: 0 5px;
    margin: 5px 0;
   }
   #app>div>textarea{
    padding: 5px;
    margin-top: 5px;
   }
   .cont div{
    height: 50px;
    border: 1px solid #acacac;
    border-radius: 5px;
    padding: 0 10px;
   }
   .cont div span{
    padding: 0 5px;
    line-height: 50px;
   }
   .cont p{
    display: inline-block;
   }
   .cont div p:nth-of-type(1){
    color: #550000;
   }
   .cont div p:nth-of-type(2){
    color: #595959;
   }
   .cont .del{
    float: right;
    line-height: 50px;
    color: #003366;
    cursor: pointer;
   }
   .cont .del:hover{
    color: #550000;
   }
   .send{
    width: 80px;
    height: 30px;
    margin-top: 10px;
   }
   hr{
    border: 1px solid #bababa;
    margin: 15px 0;
   }
   h4{
    font-weight: 400;
    color: #333;
    margin-bottom: 10px;
   }
  </style>
 </head>
 <body>
  <div id="app">
   <h2>歡迎來到吐槽大廳</h2>
   <div>
    <label>用戶名:</label><br>
    <!-- .trim去除內(nèi)容中的空格 -->
    <!-- v-model綁定表單的(uname)值 -->
    <input type="text" placeholder="用戶名" v-model.trim="uname" /><br>
    <label>吐槽內(nèi)容:</label><br>
    <textarea rows="2" cols="23" placeholder="吐槽內(nèi)容" v-model.trim="tarea"></textarea><br>
    <!-- @click="",設置點擊事件 -->
    <button class="send" @click="sendCont()">發(fā)表</button>
    <hr>
    <h4>吐槽回復:</h4>
    <!-- 遍歷list數(shù)據(jù) -->
    <div class="cont" v-for="val in list" :key="val.name">
     <div>
      <p>{{val.name}}</p><span>說:</span>
      <p>{{val.item}}</p>
      <p class="del" @click="delCont(val)">刪除</p>
     </div>
    </div>
   </div>
  </div>
  <script type="text/javascript">
   new Vue({
    el:"#app",//指定模板
    data:{
     list:[
      {"name":"beibei","item":"媽媽,我想吃烤紅薯"},
      {"name":"dian","item":"吃,吃大塊的"},
     ],
     uname:"",
     tarea:"",
    },
    methods:{
     // "發(fā)表"按鈕的點擊事件
     sendCont(){
      // 創(chuàng)建一項清單
      var item = {name:this.uname,item:this.tarea};
      // 在list的前面添加item
      this.list.unshift(item);
      // 用戶框,內(nèi)容框清空
      this.uname="";
      this.tarea="";
     },
     // 評論最后的"刪除"事件
     delCont(val){
      alert("確定刪除?");
      // 查找val在list下標
      // value遍歷的元素 當value的item/name值等于val的item/name值
      var ind = this.list.findIndex(value=>value.item===val.item);
      // 刪除list第ind個
      this.list.splice(ind,1);
     }
    }
   })
  </script>
 </body>
</html>

以上是“Vue如何實現(xiàn)發(fā)表評論功能”這篇文章的所有內(nèi)容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內(nèi)容對大家有所幫助,如果還想學習更多知識,歡迎關注億速云行業(yè)資訊頻道!

向AI問一下細節(jié)

免責聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權內(nèi)容。

vue
AI