国产chinesehdxxxx野外,国产av无码专区亚洲av琪琪,播放男人添女人下边视频,成人国产精品一区二区免费看,chinese丰满人妻videos

Vant4 DropdownMenu 下拉菜單

2023-02-16 17:55 更新

介紹

向下彈出的菜單列表。

引入

通過以下方式來全局注冊組件,更多注冊方式請參考組件注冊。

import { createApp } from 'vue';
import { DropdownMenu, DropdownItem } from 'vant';

const app = createApp();
app.use(DropdownMenu);
app.use(DropdownItem);

代碼演示

基礎用法

<van-dropdown-menu>
  <van-dropdown-item v-model="value1" :options="option1" />
  <van-dropdown-item v-model="value2" :options="option2" />
</van-dropdown-menu>
import { ref } from 'vue';

export default {
  setup() {
    const value1 = ref(0);
    const value2 = ref('a');
    const option1 = [
      { text: '全部商品', value: 0 },
      { text: '新款商品', value: 1 },
      { text: '活動商品', value: 2 },
    ];
    const option2 = [
      { text: '默認排序', value: 'a' },
      { text: '好評排序', value: 'b' },
      { text: '銷量排序', value: 'c' },
    ];

    return {
      value1,
      value2,
      option1,
      option2,
    };
  },
};

自定義菜單內容

通過插槽可以自定義 ?DropdownItem? 的內容,此時需要使用實例上的 ?toggle? 方法手動控制菜單的顯示。

<van-dropdown-menu>
  <van-dropdown-item v-model="value" :options="options" />
  <van-dropdown-item title="篩選" ref="item">
    <van-cell center title="包郵">
      <template #right-icon>
        <van-switch v-model="switch1" />
      </template>
    </van-cell>
    <van-cell center title="團購">
      <template #right-icon>
        <van-switch v-model="switch2" />
      </template>
    </van-cell>
    <div style="padding: 5px 16px;">
      <van-button type="primary" block round @click="onConfirm">
        確認
      </van-button>
    </div>
  </van-dropdown-item>
</van-dropdown-menu>
import { ref } from 'vue';

export default {
  setup() {
    const item = ref(null);
    const value = ref(0);
    const switch1 = ref(false);
    const switch2 = ref(false);
    const options = [
      { text: '全部商品', value: 0 },
      { text: '新款商品', value: 1 },
      { text: '活動商品', value: 2 },
    ];
    const onConfirm = () => {
      item.value.toggle();
    };

    return {
      item,
      value,
      switch1,
      switch2,
      options,
      onConfirm,
    };
  },
};

自定義選中態(tài)顏色

通過 ?active-color? 屬性可以自定義菜單標題和選項的選中態(tài)顏色。

<van-dropdown-menu active-color="#ee0a24">
  <van-dropdown-item v-model="value1" :options="option1" />
  <van-dropdown-item v-model="value2" :options="option2" />
</van-dropdown-menu>

向上展開

將 ?direction? 屬性值設置為 ?up?,菜單即可向上展開。

<van-dropdown-menu direction="up">
  <van-dropdown-item v-model="value1" :options="option1" />
  <van-dropdown-item v-model="value2" :options="option2" />
</van-dropdown-menu>

禁用菜單

<van-dropdown-menu>
  <van-dropdown-item v-model="value1" disabled :options="option1" />
  <van-dropdown-item v-model="value2" disabled :options="option2" />
</van-dropdown-menu>

API

DropdownMenu Props

參數(shù) 說明 類型 默認值
active-color 菜單標題和選項的選中態(tài)顏色 string #1989fa
direction 菜單展開方向,可選值為up string down
z-index 菜單欄 z-index 層級 number | string 10
duration 動畫時長,單位秒,設置為 0 可以禁用動畫 number | string 0.2
overlay 是否顯示遮罩層 boolean true
close-on-click-overlay 是否在點擊遮罩層后關閉菜單 boolean true
close-on-click-outside 是否在點擊外部元素后關閉菜單 boolean true

DropdownItem Props

參數(shù) 說明 類型 默認值
v-model 當前選中項對應的 value number | string -
title 菜單項標題 string 當前選中項文字
options 選項數(shù)組 Option[] []
disabled 是否禁用菜單 boolean false
lazy-render 是否在首次展開時才渲染菜單內容 boolean true
title-class 標題額外類名 string | Array | object -
teleport 指定掛載的節(jié)點,等同于 Teleport 組件的 to 屬性 string | Element -

DropdownItem Events

事件名 說明 回調參數(shù)
change 點擊選項導致 value 變化時觸發(fā) value
open 打開菜單欄時觸發(fā) -
close 關閉菜單欄時觸發(fā) -
opened 打開菜單欄且動畫結束后觸發(fā) -
closed 關閉菜單欄且動畫結束后觸發(fā) -

DropdownItem Slots

名稱 說明
default 菜單內容
title 自定義菜單項標題

DropdownItem 方法

通過 ref 可以獲取到 DropdownItem 實例并調用實例方法,詳見組件實例方法

方法名 說明 參數(shù) 返回值
toggle 切換菜單展示狀態(tài),傳 true 為顯示,false 為隱藏,不傳參為取反 show?: boolean -

類型定義

組件導出以下類型定義:

import type {
  DropdownMenuProps,
  DropdownItemProps,
  DropdownItemOption,
  DropdownItemInstance,
  DropdownMenuDirection,
} from 'vant';

?DropdownItemInstance? 是組件實例的類型,用法如下:

import { ref } from 'vue';
import type { DropdownItemInstance } from 'vant';

const dropdownItemRef = ref<DropdownItemInstance>();

dropdownItemRef.value?.toggle();

Option 數(shù)據(jù)結構

鍵名 說明 類型
text 文字 string
value 標識符 number | string
icon 左側圖標名稱或圖片鏈接,等同于 Icon 組件的 name 屬性 string

主題定制

樣式變量

組件提供了下列 CSS 變量,可用于自定義樣式,使用方法請參考 ConfigProvider 組件。

名稱 默認值 描述
--van-dropdown-menu-height 48px -
--van-dropdown-menu-background var(--van-background-2) -
--van-dropdown-menu-shadow 0 2px 12px fade(var(--van-gray-7), 12) -
--van-dropdown-menu-title-font-size 15px -
--van-dropdown-menu-title-text-color var(--van-text-color) -
--van-dropdown-menu-title-active-text-color var(--van-primary-color) -
--van-dropdown-menu-title-disabled-text-color var(--van-text-color-2) -
--van-dropdown-menu-title-padding 0 var(--van-padding-xs) -
--van-dropdown-menu-title-line-height var(--van-line-height-lg) -
--van-dropdown-menu-option-active-color var(--van-primary-color) -
--van-dropdown-menu-content-max-height 80% -
--van-dropdown-item-z-index 10 -

常見問題

父元素設置 transform 后,下拉菜單的位置錯誤?

把 ?DropdownMenu? 嵌套在 ?Tabs? 等組件內部使用時,可能會遇到下拉菜單位置錯誤的問題。這是因為在 Chrome 瀏覽器中,transform 元素內部的 fixed 布局會降級成 absolute 布局,導致下拉菜單的布局異常。

將 ?DropdownItem? 的 ?teleport? 屬性設置為 ?body? 即可避免此問題:

<van-dropdown-menu>
  <van-dropdown-item teleport="body" />
  <van-dropdown-item teleport="body" />
</van-dropdown-menu>


以上內容是否對您有幫助:
在線筆記
App下載
App下載

掃描二維碼

下載編程獅App

公眾號
微信公眾號

編程獅公眾號