91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

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

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

Vue.js中怎么制作自定義選擇組件

發布時間:2022-05-05 18:15:37 來源:億速云 閱讀:214 作者:zzz 欄目:大數據

本篇內容主要講解“Vue.js中怎么制作自定義選擇組件”,感興趣的朋友不妨來看看。本文介紹的方法操作簡單快捷,實用性強。下面就讓小編來帶大家學習“Vue.js中怎么制作自定義選擇組件”吧!

定制 select 標簽的設計非常困難。有時候,如果不使用樣式化的 div 和自定義 JavaScript 的結合來構建自己的腳本,那是不可能的。

Vue.js中怎么制作自定義選擇組件 

HTML

<template>
 <div
 class="custom-select"
  :tabindex="tabindex"
  @blur="open = false"
 >
  <div
  class="selected"
  :class="{open: open}"
  @click="open = !open"
 >
  {{ selected }}
 </div>
 <div
  class="items"
  :class="{selectHide: !open}"
 >
  <div
  class="item"
  v-for="(option, i) of options"
  :key="i"
  @click="selected=option; open=false; $emit('input', option)"
  >
  {{ option }}
  </div>
 </div>
 </div>
</template>

需要注意以下幾點:

  • tabindex 屬性使我們的組件能夠得到焦點,從而使它變得模糊。當用戶在組件外部單擊時, blur 事件將關閉我們的組件。

  • input 參數發出選定的選項,父組件可以輕松地對更改做出反應。

JavaScript

 <script>
 export default {
 props:{
  options:{
  type: Array,
  required: true
  },
  tabindex:{
  type: Number,
  required: false,
  default: 0
 }
 },
 data() {
 return {
  selected: this.options.length > 0 ? this.options[0] : null,
  open: false
 };
 },
 mounted(){
 this.$emit('input', this.selected);
 }
};
</script>

另外,要注意的重要事項:

我們還會在 mount 上發出選定的值,以便父級不需要顯式設置默認值。如果我們的 select 組件是較大表單的一部分,那么我們希望能夠設置正確的 tabindex 。

CSS

<style scoped>
 .custom-select {
 position: relative;
 width: 100%;
 text-align: left;
 outline: none;
 height: 47px;
 line-height: 47px;
}

.selected {
 background-color: #080D0E;
 border-radius: 6px;
 border: 1px solid #858586;
 color: #ffffff;
 padding-left: 8px;
 cursor: pointer;
 user-select: none;
}

.selected.open{
 border: 1px solid #CE9B2C;
 border-radius: 6px 6px 0px 0px;
}

.selected:after {
 position: absolute;
 content: "";
 top: 22px;
 right: 10px;
 width: 0;
 height: 0;
 border: 4px solid transparent;
 border-color: #fff transparent transparent transparent;
}

.items {
 color: #ffffff;
 border-radius: 0px 0px 6px 6px;
 overflow: hidden;
 border-right: 1px solid #CE9B2C;
 border-left: 1px solid #CE9B2C;
 border-bottom: 1px solid #CE9B2C;
 position: absolute;
 background-color: #080D0E;
 left: 0;
 right: 0;
}

.item{
 color: #ffffff;
 padding-left: 8px;
 cursor: pointer;
 user-select: none;
}

.item:hover{
 background-color: #B68A28;
}

.selectHide {
 display: none;
}
</style>

該 CSS只是一個示例,你可以按照你的需求隨意修改樣式。

到此,相信大家對“Vue.js中怎么制作自定義選擇組件”有了更深的了解,不妨來實際操作一番吧!這里是億速云網站,更多相關內容可以進入相關頻道進行查詢,關注我們,繼續學習!

向AI問一下細節

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

AI

康保县| 邹平县| 阳春市| 锦屏县| 盐边县| 高安市| 桐梓县| 和林格尔县| 平果县| 江陵县| 南京市| 剑阁县| 湟源县| 双流县| 清河县| 子长县| 托克逊县| 禄丰县| 酒泉市| 顺平县| 大城县| 太谷县| 偏关县| 榆林市| 老河口市| 丹寨县| 奉化市| 和平区| 张家界市| 蒙城县| 乐东| 西充县| 黄骅市| 达日县| 长兴县| 彰化市| 松阳县| 榆林市| 稷山县| 韶关市| 田东县|