欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

vue中下拉框組件的封裝方式

 更新時間:2023年01月18日 11:55:09   作者:田湖_怎么了  
這篇文章主要介紹了vue中下拉框組件的封裝方式,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教

vue下拉框組件的封裝

原理

vue element中,需要封裝一個對應(yīng)的下拉款組件。

第一步:在api_domain.js中添加后臺的請求接口

//獲取下拉框的接口 從redis中
  domainGetDomainKeyRedis: params => { 
	  return axios.post('domain-manager/domain/getDomainKeyRedis',qs.stringify(params));
},

//獲取下拉框的接口 從DB中
  domainGetDomainKeyDB: params => { 
	  return axios.post('domain-manager/domain/getDomainKeyDB',qs.stringify(params));
},

第二步,在文件夾api中新建getSelect.js,內(nèi)容

/**
 * _this為傳過來的this
 * 
 * 根據(jù)參數(shù)str,去獲取到對應(yīng)的下拉框的值
 * 
 * paramName,接收的數(shù)組,如'type'
 * 
 * 先去redis總查詢,如果沒有值,再去數(shù)據(jù)庫中查詢
 */
import api from '@/api/api_domain'


export function GetSelect(_this,str,paramName) {
	
    let para = {
		key: str
	};
	
	if(typeof str === "undefined" || str == ""){
	//	return options;
	}else{
		_this.$api.domain.domainGetDomainKeyRedis(para).then((res) => {
																									
			_this[paramName] = res.data.data.listDomainDefine;
												
		}).catch((err)=>{
	    console.log(err);
	  });
	}
}

使用

引入js

import {GetSelect} from '@/api/getSelect'

取值

//獲取資源類型GetSelect(this,'resType','type');

resType,是傳遞到后臺方法的查詢條件,

就是在【域定義管理】中簡稱,點擊【域值】按鈕可看到對應(yīng)的下拉框數(shù)據(jù)

type,是接受查詢出的list的參數(shù),在頁面中我定義了type: [],用來接收,資源類型下拉框中的值

在頁面中

<el-form-item label="類型" prop="resType">	
	<el-select v-model="addForm.resType" filterable placeholder="請選擇" style="width:100%">
		<el-option v-for="item in type" :key="item.key " :label="item.name" :value="item.key">
		</el-option>
	</el-select>					
</el-form-item>

在table中怎么去顯示類型為中文名稱

<el-table-column prop="ptType" label="類型" min-width="10%" :formatter="formatType" >
			</el-table-column>

注意: :formatter=“formatType”

然后寫一個方法formatType

formatType: function (row, column) {//類型轉(zhuǎn)換
				
				for(var a = 0 ;a< this.options.length ; a++){
					if(row.ptType == this.options[a].key){
						return this.options[a].name;
					}
				}
				
			},

vue封裝遠(yuǎn)程下拉框組件

之前封裝了一個遠(yuǎn)程搜索的輸入框,靜態(tài)在Vue官網(wǎng)看到一個類似的遠(yuǎn)程搜索下拉框,今天也封裝一個遠(yuǎn)程搜索下拉框,面對不同的需求

我們修改了官方提供的代碼來封裝了

父組件

RemoteSearch.vue

vue的參數(shù)是可以通過封裝在props內(nèi),被其他界面引用

注意:

一:js中在調(diào)用json格式數(shù)組的值的時候——有兩種形式

以下為dataList數(shù)組

  • ?形式一:dataList[0].name
  • 形式二:dataList[0][name]

在有些時候會把**.變量**識別成調(diào)用,所以在一些情況下使用第二個效果更好

js的數(shù)組手動設(shè)置值(給dataList設(shè)置一個value值)

dataList.value = ?

以下為引用的vue界面

<template>
  <div>
    <RemoteSearch :choose-flag="0" :auto-complete-column="name" ref="refreshData"></RemoteSearch>
    <el-button type="primary" @click="refreshChartSearch" style="margin-left: 10px">重置</el-button>
  </div>
</template>

<script>
import RemoteSearch from "@/components/select/RemoteSearch";
export default {
  components: {
    RemoteSearch
  },
  data(){
    return {
    }
  },
  methods:{
    refreshChartSearch(){
      this.$nextTick(() => {
        this.$refs.refreshData.refreshData();
        //DOM渲染完畢后就能正常獲取了
      })
    },
  },
}
</script>

<style scoped>

</style>

只需要通過import導(dǎo)入對應(yīng)的組件,通過components來調(diào)用,并通過類似標(biāo)簽的形式來聲明

子組件通過父組件提供的props的參數(shù)重寫(修改)父組件的參數(shù)

如果子組件不調(diào)用,props的參數(shù)就會是默認(rèn)的值。

子組件可以通過在標(biāo)簽內(nèi)使用:特定值的方式來修改值

重置的按鈕實現(xiàn),可以參考之前封裝遠(yuǎn)程搜索輸入框的帖子

這里父組件的placeholder也可以做成讓子組件自己選擇的,但是我這里的形式比較通用,就沒有修改,有興趣的可以自行優(yōu)化

placeholder="請輸入內(nèi)容"

總結(jié)

以上為個人經(jīng)驗,希望能給大家一個參考,也希望大家多多支持腳本之家。

相關(guān)文章

  • Vue中computed及watch區(qū)別實例解析

    Vue中computed及watch區(qū)別實例解析

    這篇文章主要介紹了Vue中computed及watch區(qū)別實例解析,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下
    2020-08-08
  • Vue頁面骨架屏注入方法

    Vue頁面骨架屏注入方法

    這篇文章主要介紹了Vue頁面骨架屏注入的操作,非常不錯,具有一定的參考借鑒價值,需要的朋友可以參考下
    2018-05-05
  • vue.js實例todoList項目

    vue.js實例todoList項目

    本篇文章主要介紹了vue.js實例todoList項目,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-07-07
  • element ui中表單el-form的label如何設(shè)置寬度

    element ui中表單el-form的label如何設(shè)置寬度

    這篇文章主要介紹了element ui中表單el-form的label如何設(shè)置寬度,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-10-10
  • Vue中如何實現(xiàn)proxy代理

    Vue中如何實現(xiàn)proxy代理

    本篇文章主要介紹了Vue中如何實現(xiàn)proxy代理,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2018-04-04
  • VUE v-bind 數(shù)據(jù)綁定的示例詳解

    VUE v-bind 數(shù)據(jù)綁定的示例詳解

    這篇文章主要介紹了VUE v-bind 數(shù)據(jù)綁定,簡單點來說就是對 HTML 中的元素,我們可以使用 v-bind 來進(jìn)行綁定和動態(tài)的數(shù)據(jù)輸出,本文結(jié)合示例代碼給大家介紹的非常詳細(xì),需要的朋友可以參考下
    2023-05-05
  • Vue根據(jù)條件添加click事件的方式

    Vue根據(jù)條件添加click事件的方式

    今天小編就為大家分享一篇Vue根據(jù)條件添加click事件的方式,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2019-11-11
  • 解讀vue頁面監(jiān)聽store值改變問題

    解讀vue頁面監(jiān)聽store值改變問題

    這篇文章主要介紹了解讀vue頁面監(jiān)聽store值改變問題,具有很好的參考價值,希望對大家有所幫助。
    2022-10-10
  • Vue動態(tài)生成表格的行和列

    Vue動態(tài)生成表格的行和列

    這篇文章主要為大家詳細(xì)介紹了Vue動態(tài)生成表格的行和列,文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2019-07-07
  • Vue清除定時器setInterval優(yōu)化方案分享

    Vue清除定時器setInterval優(yōu)化方案分享

    這篇文章主要介紹了Vue清除定時器setInterval優(yōu)化方案分享,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2020-07-07

最新評論