欧美一级特黄大片做受成人-亚洲成人一区二区电影-激情熟女一区二区三区-日韩专区欧美专区国产专区

Vue.js如何實(shí)現(xiàn)微信公眾號(hào)菜單編輯器功能

這篇文章將為大家詳細(xì)講解有關(guān)Vue.js如何實(shí)現(xiàn)微信公眾號(hào)菜單編輯器功能,小編覺(jué)得挺實(shí)用的,因此分享給大家做個(gè)參考,希望大家閱讀完這篇文章后可以有所收獲。

為廣信等地區(qū)用戶提供了全套網(wǎng)頁(yè)設(shè)計(jì)制作服務(wù),及廣信網(wǎng)站建設(shè)行業(yè)解決方案。主營(yíng)業(yè)務(wù)為成都網(wǎng)站設(shè)計(jì)、成都做網(wǎng)站、廣信網(wǎng)站設(shè)計(jì),以傳統(tǒng)方式定制建設(shè)網(wǎng)站,并提供域名空間備案等一條龍服務(wù),秉承以專業(yè)、用心的態(tài)度為用戶提供真誠(chéng)的服務(wù)。我們深信只要達(dá)到每一位用戶的要求,就會(huì)得到認(rèn)可,從而選擇與我們長(zhǎng)期合作。這樣,我們也可以走得更遠(yuǎn)!

實(shí)現(xiàn)菜單刪除方法

在vue實(shí)例中添加刪除菜單方法,根據(jù)選中的菜單級(jí)別和索引來(lái)刪除。

methods: {
 //刪除菜單
 delMenu:function(){
  //刪除主菜單
  if(this.selectedMenuLevel()==1&&confirm('刪除后菜單下設(shè)置的子菜單也將被刪除')){
   if(this.selectedMenuIndex===0){
    this.menu.button.splice(this.selectedMenuIndex, 1);
    this.selectedMenuIndex = 0;
   }else{
    this.menu.button.splice(this.selectedMenuIndex, 1);
    this.selectedMenuIndex -=1;
   }
   if(this.menu.button.length==0){
    this.selectedMenuIndex = ''
   }
  //刪除子菜單
  }else if(this.selectedMenuLevel()==2){
   if(this.selectedSubMenuIndex===0){
    this.menu.button[this.selectedMenuIndex].sub_button.splice(this.selectedSubMenuIndex, 1);
    this.selectedSubMenuIndex = 0;
   }else{
    this.menu.button[this.selectedMenuIndex].sub_button.splice(this.selectedSubMenuIndex, 1);
    this.selectedSubMenuIndex -= 1;
   }
   if(this.menu.button[this.selectedMenuIndex].sub_button.length==0){
    this.selectedSubMenuIndex = ''
   }
  }
 },
}

將方法綁定了菜單編輯界面

<div class="weixin-menu-detail">
 <!-- 顯示選中的菜單和刪除菜單按鈕 -->
 <div class="menu-input-group" >
  <div class="menu-name">{{menu.button[selectedMenuIndex].name}}</div>
   <div class="menu-del" @click="delMenu">刪除菜單</div>
  </div>
 </div>
 </div>

檢查菜單名稱輸入長(zhǎng)度

用v-model指令在輸入框綁定菜單名,@input監(jiān)聽(tīng)輸入事件來(lái)檢查輸入的菜單名長(zhǎng)度,超出上限則顯示提示

data:{
 menuNameBounds:false,//菜單長(zhǎng)度超出上限標(biāo)記
},
methods:{
 //判斷菜單名長(zhǎng)度
 checkMenuName:function(val){
  if(this.selectedMenuLevel()==1&&this.getMenuNameLen(val)<=8){
   this.menuNameBounds=false
  }else if(this.selectedMenuLevel()==2&&this.getMenuNameLen(val)<=16){
   this.menuNameBounds=false
  }else{
   this.menuNameBounds=true
  }
 },
 //獲取字符串中文字符長(zhǎng)度
 getMenuNameLen: function (val) {
  var len = 0;
  for (var i = 0; i < val.length; i++) {
   var a = val.charAt(i);
   a.match(/[^\x00-\xff]/ig) != null?len += 2:len += 1;
  }
  return len;
 }
}

添加菜單編輯界面和事件監(jiān)聽(tīng)

v-model指令用來(lái)綁定菜單名輸入框的值,@input監(jiān)聽(tīng)輸入事件來(lái)檢查輸入的菜單名長(zhǎng)度,長(zhǎng)度超出上線則顯示提示

<div class="weixin-menu-detail">
 <div class="menu-input-group">
  <div class="menu-label">菜單名稱</div>
  <div class="menu-input">
   <input type="text" name="name" placeholder="請(qǐng)輸入菜單名稱" class="menu-input-text" v-model="menu.button[selectedMenuIndex].name" @input="checkMenuName(menu.button[selectedMenuIndex].name)">
   <!-- 這里用v-show來(lái)判斷是否超過(guò)上限,menuNameBounds為true則顯示 -->
   <p class="menu-tips"  v-show="menuNameBounds">字?jǐn)?shù)超過(guò)上限</p>
   <p class="menu-tips">字?jǐn)?shù)不超過(guò)4個(gè)漢字或8個(gè)字母</p>
  </div>
 </div>
</div>

截圖工具不顯示刪除的彈框,將就一下吧...

Vue.js如何實(shí)現(xiàn)微信公眾號(hào)菜單編輯器功能

實(shí)現(xiàn)選擇菜單類型方法

微信菜單有多種類型所以需要做個(gè)下拉列表,選中下拉項(xiàng)后顯示該項(xiàng)的內(nèi)容

先給每個(gè)菜單添加下類型

data:{
 "menu": {
  "button": [
  {
   "type": "click",
   "name": "主菜單1",
   "key": "測(cè)試key",
   "sub_button": []
  },
  {
   "name": "主菜單2",
   "sub_button": [
   {
    "type": "view",
    "name": "子菜單",
    "url": "https://cn.vuejs.org/v2/guide/"
   }]
  },
  {
   "name": "主菜單3",
   "sub_button": [
   {
    "type": "view",
    "name": "子菜單",
    "url": "https://cn.vuejs.org/v2/guide/"
   }
  }]
 }
}

創(chuàng)建的下拉列表也使用v-model指令來(lái)綁定選中的菜單類型

//獲取菜單類型 1. view網(wǎng)頁(yè)類型,2. media_id類型和view_limited類型 3. click點(diǎn)擊類型,4.miniprogram表示小程序類型
methods: {
 selectedMenuType: function () {
  switch (this.menu.button[this.selectedMenuIndex].type) {
   case 'view':return 1;
   case 'media_id':return 2;
   case 'click':return 3;
   case 'miniprogram':return 4;
  }
 }
}
<div class="weixin-menu-detail">
 <div class="menu-input-group">
  <div class="menu-label">菜單內(nèi)容</div>
  <div class="menu-input">
   <select v-model="menu.button[selectedMenuIndex].type" name="type" class="menu-input-text">
    <option value="view">跳轉(zhuǎn)網(wǎng)頁(yè)(view)</option>
    <option value="media_id">發(fā)送消息(media_id)</option>
    <option value="miniprogram">打開(kāi)指定小程序(miniprogram)</option>
    <option value="click">自定義點(diǎn)擊事件(click)</option>
   </select>
  </div>
 </div>
 <!-- 由于內(nèi)容類型很多,就以click類型為例 -->
 <div class="menu-content" v-if="selectedMenuType()==3">
  <div class="menu-input-group">
   <p class="menu-tips">用于消息接口推送,不超過(guò)128字節(jié)</p>
   <div class="menu-label">菜單KEY值</div>
   <div class="menu-input">
    <input type="text" class="menu-input-text" v-model="menu.button[selectedMenuIndex].key">
   </div>
  </div>
 </div>
</div>

Vue.js如何實(shí)現(xiàn)微信公眾號(hào)菜單編輯器功能

菜單的添加、編輯、刪除功能基本完成了,總結(jié)一下學(xué)習(xí)到的知識(shí)

  • 數(shù)組對(duì)象的修改使用Vue的變異方法參考

  • 阻止事件冒泡使用Vue的事件修飾符參考

  • 在切換菜單類型會(huì)有一些沒(méi)有聲明屬性,但vue初始化實(shí)例后不會(huì)監(jiān)聽(tīng)沒(méi)有聲明的屬性,所以要使用Vue.set方法來(lái)將屬性添加到菜單對(duì)象上參考

彈窗組件使用的是layer

素材列表使用的模版是art-template

關(guān)于“Vue.js如何實(shí)現(xiàn)微信公眾號(hào)菜單編輯器功能”這篇文章就分享到這里了,希望以上內(nèi)容可以對(duì)大家有一定的幫助,使各位可以學(xué)到更多知識(shí),如果覺(jué)得文章不錯(cuò),請(qǐng)把它分享出去讓更多的人看到。

網(wǎng)站欄目:Vue.js如何實(shí)現(xiàn)微信公眾號(hào)菜單編輯器功能
分享URL:http://aaarwkj.com/article10/pchgdo.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供微信公眾號(hào)網(wǎng)站改版、網(wǎng)站導(dǎo)航網(wǎng)頁(yè)設(shè)計(jì)公司、品牌網(wǎng)站制作、企業(yè)網(wǎng)站制作

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來(lái)源: 創(chuàng)新互聯(lián)

綿陽(yáng)服務(wù)器托管
亚洲男人天堂黄色av| 国产亚洲精品视频在线| 国产精品网站在线观看不卡| 欧美劲爆三级免费观看| 肉肉开房天天操夜夜操| 久久99精品综合国产女同| 亚洲国产成人久久综合区| 美女视频黄的日本的日进去了| 日韩毛片免费看美日韩毛片| 日本欧美国产污黄在线观看| 国产精品久久久在线视频| 日本成熟亚洲中文字幕的| 日韩欧美亚洲国产另类| 日韩精品专区在线影院重磅| 国产男女免费视频观看| 亚洲高清中文字幕专区| 日韩精品国产专区一区| 在线观看亚洲毛片网站| 亚洲熟女精品不卡一区二区| 手机不卡高清播放一区二区| 国产一区二区三区精品久| 免费女同一区二区三区| 国产激情福利一区二区| 日日骚国产欧美一区二区| 天堂av在线播放观看| 国产一级r内射视频播放| 深夜av免费在线观看| 国产精品伦一区二区三级| 国产一区av剧情巨作| 亚洲社区一区二区三区四区| 不卡一区二区黄色av| 日韩女优中文字幕在线播放| 国产av专区久久伊人亚洲| 日韩成人一级片在线观看| 蜜臀av成人精品蜜臀av| 欧美又粗又成人大视频| 国产原创av剧情在线观看| 最新国产不卡一区二区| 日本在线精品在线观看| 亚洲美女插入av网络导航| 欧美高清视频免费播放|