当前位置: 首页 > news >正文

网站 内部搜索引擎百度天眼查公司

网站 内部搜索引擎,百度天眼查公司,建站工具大全,先做产品网站还是appel-select下拉获取数据 1.解决问题2.封装MyScrollSelect组件3.使用MyScrollSelect组件 1.解决问题 场景:下拉数据量过大,后端提供一个分页查询接口;需要每次滚动加载下一页的下拉数据 且单选的状态,需要支持回显,通过n…

el-select下拉获取数据

    • 1.解决问题
    • 2.封装MyScrollSelect组件
    • 3.使用MyScrollSelect组件

1.解决问题

场景:下拉数据量过大,后端提供一个分页查询接口;需要每次滚动加载下一页的下拉数据
且单选的状态,需要支持回显,通过name名称查询回显;–本文已包含
如果是多选回显,可以让后端提供一个根据idList能反向找到对应id的下拉集合的接口;–可自己试试

2.封装MyScrollSelect组件

<template><div>list长度:{{ list.length }}</div><div>$attrs:{{ $attrs }}</div><el-select @change="changeVal" v-bind="$attrs" :remote-method="remoteMethod" style="width: 100%"><div v-infinite-scroll="loadMore" style="overflow: hidden"><el-option v-for="item in list" :key="item[valueKey]" :label="item[labelKey]" :value="item[valueKey]" /><!-- 下拉底部加载提示 --><div v-if="loading" class="loading-text">加载中...</div></div></el-select>
</template><script setup >
import { ref, watch, onMounted } from "vue"
import { debounce } from "lodash"const emit = defineEmits(['update:searchName']);const props = defineProps({// v-model绑定值不为空时传递初始数据列表initialOptions: {type: Array,default: () => []},// 传入对应的列表加载apimethods: {type: Function,required: true // 或者 true,取决于它是否必须被传递},// 传入查询关键字searchKey: {type: String,default: ""},// 所选key对用namesearchName: {type: String,default: undefined},labelKey: {type: String,default: "name"},valueKey: {type: String,default: "id"},// 查询的其他参数queryData: {type: Object,default: () => { }},
})const isMounted = ref(false)
const loading = ref(false)const list = ref([]) // 选项列表
const queryFrom = ref({pageNum: 1,totalPage: 1,pageSize: 20
})// 自定义远程搜索方法
const remoteMethod = (query) => {queryFrom.value.pageNum = 1list.value = []queryFrom.value[props.searchKey] = queryqueryFrom.value = { ...queryFrom.value, ...props.queryData }getList()
}// 调用props.methods获取下拉数据
const getList = () => {loading.value = trueprops.methods(queryFrom.value).then(res => {console.log('%c【' + 'res' + '】打印', 'color:#fff;background:#0f0', res)list.value = [...list.value, ...res.records]queryFrom.value.totalPage = Math.ceil(res.total / 20) // 计算总页数 不是总数}).finally(() => {loading.value = false})
}// 无限滚动触底加载
const loadMore = debounce(() => {if (queryFrom.value.pageNum >= queryFrom.value.totalPage || loading.value) returnqueryFrom.value.pageNum++getList()
}, 200)// 根据id回显name
const changeVal = (e) => {list.value.forEach(ele => {if (ele[props.valueKey] === e) {emit('update:searchName', ele[props.labelKey])}})
}// 监听 initialOptions 的变化,用于加载初始值
watch(() => props.initialOptions,newVal => {// 如果 modelValue 中的值还未加载到选项中,加载这些数据if (newVal && newVal.length > 0) {list.value.push(...props.initialOptions)}},{ immediate: true }
)onMounted(() => {isMounted.value = true// 获取初始数据if (props.searchName) {remoteMethod(props.searchName) // 根据name回显} else {getList()}
})
</script>
<style scoped>
.loading-text {padding: 5px;text-align: center;color: #999;font-size: 12px;
}
</style>

3.使用MyScrollSelect组件

<template><div class="page-view wbg pall"><pre>{{ form }}</pre><div style="margin-top: 50px">多选:只能存id</div><MyScrollSelectv-if="isMounted"ref="reviewStageRef"v-model="form.idList1":placeholder="'滚动加载或搜索-单选'"clearablefilterableremotecollapse-tagscollapse-tags-tooltipmultiple:initialOptions="initialOptions":methods="getDeviceNameListApi"searchKey="terminalDeviceName"valueKey="id"labelKey="terminalDeviceName"/><div style="margin-top: 50px">单选:可存id和name 根据name可回显</div><MyScrollSelectv-if="isMounted"ref="reviewStageRef"v-model="form.terminalDeviceId"v-model:searchName="form.terminalDeviceName":placeholder="'滚动加载或搜索-单选'"clearablefilterableremote:initialOptions="initialOptions":methods="getDeviceNameListApi"searchKey="terminalDeviceName"valueKey="id"labelKey="terminalDeviceName"/></div>
</template><script setup>
import { onMounted, ref } from 'vue'
import { getDeviceNameListApi } from "@/api/ipManagement.js" // 后端获取下拉分页接口defineOptions({name: 'FactorySiteAddressLedger'
})const isMounted = ref(false)
const form = ref({idList1: [], // 多选参数terminalDeviceId: '710241160000004443', // 单选参数terminalDeviceName: '益海电厂网监工作站',
})const reviewStageRef = ref(null)const initialOptions = ref([]) // 初始下拉数据onMounted(() => {isMounted.value = true
})
</script>
<style lang="scss" scoped></style>
http://www.mnyf.cn/news/40046.html

相关文章:

  • 西樵做网站seo搜索引擎优化工资薪酬
  • 企业官方网站开发平台河南seo推广
  • 个人网站官网落实好疫情防控优化措施
  • 复制链接提取视频软件下载seo网站优化方案摘要
  • 网站电话转化率seo推广方法有哪些
  • 西安网站建设收费标准logo网站设计
  • 电子商务网站开发目的深圳海外推广
  • 建站园百度推广培训
  • 拦截网站做跳转2023年4 5月份疫情结束吗
  • 推广做网站怎么样优化大师手机版下载
  • wordpress美女图片站主题b2b免费推广网站
  • 使用国外空间的网站网站一键收录
  • 手机网站如何测试seo网络推广机构
  • 曲阳住房和城乡建设局网站百度广告联盟app
  • 建设商业门户网站的重要免费的关键词优化软件
  • 新型建筑模板样品图片搜索引擎排名优化建议
  • 网站建设技术人员招聘深圳网络推广服务是什么
  • 滨州做网站建设seo是什么及作用
  • 怎么去找做网站的北京百度seo排名公司
  • 网站怎么做留言抖音关键词搜索排名收费
  • 域名有了主机有了如何做网站竞价代运营公司哪家好
  • 做网站如何写代码全网关键词指数查询
  • 自贡百度做网站多少钱网站开发公司
  • 做导航网站赚钱北京广告公司
  • 进行目的地网站建设seo技巧与技术
  • 做外汇有哪些正规的网站企业关键词大全
  • 个人网站开发协议在线识别图片找原图
  • 生物网站建设亚马逊排名seo
  • 网站服务器和网站备案吗环球网今日疫情消息
  • 购物网站 购物车界面如何做安阳企业网站优化外包