• uniapp模仿下拉框实现文字联想功能 - uniapp输入联想(官方样式-附源码)


    一、效果

    废话不多说,上效果图:

    • 在下方的:
      在这里插入图片描述
    • 在上方的:
      在这里插入图片描述

    二、源码

    一般是个输入框,输入关键词,下拉一个搜索列表。
    ElementUI有提供,但uniapp官网没提供这么细,特简单扩展了一下:

    1、/ components / input-search.vue

    <template>
    	<view class="uni-stat__select" :class="'uni-stat__select_'+algin">
    		<view class="uni-stat-box" :class="{'uni-stat__actived': current}">
    			<view class="uni-select__input-box" @click="toggleSelector">
    				<slot ref="slot">slot>
    			view>
    			<view class="uni-select--mask" v-if="showSelector" @click="toggleSelector" />
    			<view class="uni-select__selector" v-if="showSelector && current">
    				<view class="uni-popper__arrow">view>
    				<scroll-view scroll-y="true" class="uni-select__selector-scroll">
    					<view class="uni-select__selector-empty" v-if="loadState==0">
    						<text class="cbbb">加载中...text>
    					view>
    					<view class="uni-select__selector-empty" v-else-if="loadState== 1">
    						<text class="cbbb">请求失败,请稍后重试!text>
    					view>
    					<view class="uni-select__selector-empty" v-else-if="loadState== 3">
    						<text class="cbbb">请输入关键词联想~text>
    					view>
    					<view class="uni-select__selector-empty" v-else-if="loadState== 4">
    						<text class="cbbb">没有相关数据!text>
    					view>
    					<view class="uni-select__selector-empty" v-else-if="!list || list.length === 0">
    						<text>{{emptyTips}}text>
    					view>
    					<view v-else class="uni-select__selector-item" v-for="(item,index) in list" :key="index" @click="change(item)">
    						<text :class="{'uni-select__selector__disabled': item.disable}">{{formatItemName(item)}}text>
    					view>
    				scroll-view>
    			view>
    		view>
    	view>
    template>
    <script>
    	export default {
    		name: "input-search",
    		......
    	}
    script>
    <style lang="scss" scoped>
    	$uni-border-3: #e5e5e5;
    
    	......
    style>
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20
    • 21
    • 22
    • 23
    • 24
    • 25
    • 26
    • 27
    • 28
    • 29
    • 30
    • 31
    • 32
    • 33
    • 34
    • 35
    • 36
    • 37
    • 38
    • 39
    • 40
    • 41
    • 42
    • 43
    • 44

    2、/ pages / xxx / demo.vue

    <template>
    	<input-search :type="1" :value="handleResult" algin="top" @confirm="confirmInputSearch($event, 'handleResult')">
    		<input class="uni-input" type="text" placeholder="请填写结果" v-model="handleResult" />
    	input-search>
    	
    template>
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    import inputSearch from "@/components/input-search.vue";
    export default {
    	components: {
    		inputSearch,
    	},
    	data() {
    		handleResult: "",
    	},
    	methods: {
    		confirmInputSearch(val, key) {
    			this.$set(this, key, val);
    		},
    	},
    	//......
    },
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15

    源码链接:uniapp模仿下拉框实现文字联想功能 - uniapp输入联想(官方样式-附源码)
    源码链接:uniapp模仿下拉框实现文字联想功能 - uniapp输入联想(官方样式-附源码)
    源码链接:uniapp模仿下拉框实现文字联想功能 - uniapp输入联想(官方样式-附源码)

    三、参数说明:

    名称类型说明
    typeint词条类型,如果同个页面有多个联想,
    且联想内容不一致时,用此字段与接口对接
    valueString词条内容
    alginStringnull | top,弹出框的方向,默认bottom
    emptyTipsString当词条内容为空时,显示的文本内容(未纳入)
    @confirmMethod选中事件,点击了联想内容的一个。返回联想内容text

    四、续

    • 功能优势:

      • 官方样式,好看啦
      • 可扩展
      • 支持input、textarea等控件
    • 扩展

      • 输出格式 format
      • 禁用 item内容
      • 未完待续…

    [The end]

  • 相关阅读:
    【设计大赛】基于RT-Thread和RA6M4实现samba服务的移动网盘
    ZZULIOJ1064: 加密字符
    【HCIE】VXLAN
    python数学建模--时间序列模型--指数平滑
    MapReduce(三)
    【TensorFlow】TensorFlow中的三种计算图
    go设计模式——适配器模式 2
    如何利用ProcessOn 做资产管理流程图
    什么是粉红喜马拉雅盐,比普通盐更好吗?
    Linux下:文件与路径、用户管理、常用命令、vim
  • 原文地址:https://blog.csdn.net/qq_26599807/article/details/136486141