ele-h5项目使用vue3+vite开发:第二节、search 搜索框组件开发

如何设计一个组件

 需求分析

 布局

  • content
    • left-icon
    • body
    • input-control
    • right-icon
  • action

功能

使用 defineEmits 定义组件的事件

在组件的script setup 里如何定义事件

  • 使用defineEmits()定义
  • 先声明事件接口
  • <script setup lang="ts">
    interface IProps {showAction?: booleanbackground?: stringplaceholder?: stringshape?: stringmodelValue?: string | number
    }const props = defineProps<IProps>()// 声明事件接口
    interface IEmits {(e: 'search', v?: string | number): void(e: 'cancel'): void(e: 'clear'): void(e: 'update:modelValue', v?: string | number): void
    }// 定义事件变量
    const emits = defineEmits<IEmits>()const onKeyPress = (e: KeyboardEvent) => {const ENTER_CODE = 13if (ENTER_CODE === e.keyCode) {e.preventDefault()
    //使用定义事件里声明事件接口中的某个事件emits('search', props.modelValue)}
    }const onClear = () => {
    //使用定义事件里声明事件接口中的某个事件emits('clear')
    //使用定义事件里声明事件接口中的某个事件emits('update:modelValue', '')
    }
    </script><template><div class="op-search" :class="{ 'op-search--show-action': showAction }" :style="{ background }"><div class="op-search__content" :class="shape ? `op-search__content--${shape}` : ''"><div class="op-cell op-search__field"><div class="op-field__left-icon"><VanIcon name="search" /></div><div class="op-cell__value"><div class="op-field__body"><inputtype="search"class="op-field__control":value="modelValue":placeholder="placeholder"@keypress="onKeyPress"//使用定义事件里声明事件接口中的某个事件, 以及传递input输入框里的值@input="(e) => emits('update:modelValue', (e.target as HTMLInputElement).value)"/><div v-if="$slots['right-icon']" class="op-field__right-icon"><slot name="right-icon"></slot></div><VanIconv-else-if="modelValue"name="clear"class="op-field__clear-icon"
    //使用定义的函数事件,触发里面的定义事件里声明事件接口中的某个事件@click="onClear"/></div></div></div></div><div v-if="showAction" class="op-search__action"><slot name="action">
    //定义事件里声明事件接口中的某个事件<div @click="emits('cancel')">取消</div></slot></div></div>
    </template>

如何定义组件的 v-model

在组件的script setup 里如何定义 v-model 参数

  • 声明接口属性,定义v-model双向绑定的变量参数。
  • 使用定义的v-model双向绑定的变量参数
  • <script setup lang="ts">//声明变量参数的接口属性
    interface IProps {showAction?: booleanbackground?: stringplaceholder?: stringshape?: stringmodelValue?: string | number
    }// 定义v-model双向绑定使用的变量参数
    const props = defineProps<IProps>()interface IEmits {(e: 'search', v?: string | number): void(e: 'cancel'): void(e: 'clear'): void(e: 'update:modelValue', v?: string | number): void
    }const emits = defineEmits<IEmits>()const onKeyPress = (e: KeyboardEvent) => {const ENTER_CODE = 13if (ENTER_CODE === e.keyCode) {e.preventDefault()//在script setup中使用定义v-model双向绑定使用的变量参数emits('search', props.modelValue)}
    }const onClear = () => {emits('clear')emits('update:modelValue', '')
    }
    </script><template>
    //在template中使用定义v-model双向绑定使用的变量参数 showAction background shape<div class="op-search" :class="{ 'op-search--show-action': showAction }" :style="{ background }"><div class="op-search__content" :class="shape ? `op-search__content--${shape}` : ''"><div class="op-cell op-search__field"><div class="op-field__left-icon"><VanIcon name="search" /></div><div class="op-cell__value"><div class="op-field__body">
    //在template中使用定义v-model双向绑定使用的变量参数 modelValue placeholder<inputtype="search"class="op-field__control":value="modelValue":placeholder="placeholder"@keypress="onKeyPress"@input="(e) => emits('update:modelValue', (e.target as HTMLInputElement).value)"/><div v-if="$slots['right-icon']" class="op-field__right-icon"><slot name="right-icon"></slot></div>
    //在template中使用定义v-model双向绑定使用的变量参数 modelValue <VanIconv-else-if="modelValue"name="clear"class="op-field__clear-icon"@click="onClear"/></div></div></div></div>
    //在template中使用定义v-model双向绑定使用的变量参数 showAction<div v-if="showAction" class="op-search__action"><slot name="action"><div @click="emits('cancel')">取消</div></slot></div></div>
    </template>
    

是的

如何使用 CSS 变量

定义css变量,使用var(--van-padding-xs)格式来书写vue3的css变量,可以在script setup中进行自定义css变量值

  • 在组件中使用css变量
  • 
    <template><div class="op-search" :class="{ 'op-search--show-action': showAction }" :style="{ background }"><div class="op-search__content" :class="shape ? `op-search__content--${shape}` : ''"><div class="op-cell op-search__field"><div class="op-field__left-icon"><VanIcon name="search" /></div><div class="op-cell__value"><div class="op-field__body"><inputtype="search"class="op-field__control":value="modelValue":placeholder="placeholder"@keypress="onKeyPress"@input="(e) => emits('update:modelValue', (e.target as HTMLInputElement).value)"/><div v-if="$slots['right-icon']" class="op-field__right-icon"><slot name="right-icon"></slot></div><VanIconv-else-if="modelValue"name="clear"class="op-field__clear-icon"@click="onClear"/></div></div></div></div><div v-if="showAction" class="op-search__action"><slot name="action"><div @click="emits('cancel')">取消</div></slot></div></div>
    </template><style lang="scss">
    :root {// 定义css变量var(变量格式),可以让引用组件的父组件自定义css值--op-search-padding: 10px var(--van-padding-sm);--op-search-background-color: var(--van-background-color-light);--op-search-content-background: var(--van-gray-1);--op-search-left-icon-color: var(--van-gray-6);--op-search-action-padding: 0 var(--van-padding-xs);--op-search-action-text-color: var(--van-text-color);--op-search-action-font-size: var(--van-font-size-md);--op-search-input-height: 34px;
    }.op-search {display: flex;align-items: center;box-sizing: border-box;padding: var(--op-search-padding);background: var(--op-search-background-color);&--show-action {padding-right: 0;}&__content {display: flex;flex: 1;padding-left: var(--van-padding-sm);background: var(--op-search-content-background);border-radius: var(--van-border-radius-sm);&--round {border-radius: var(--van-radius-max);}}&__action {padding: var(--op-search-action-padding);color: var(--op-search-action-text-color);font-size: var(--op-search-action-font-size);line-height: var(--op-search-input-height);cursor: pointer;user-select: none;}&__field {flex: 1;padding: 5px var(--van-padding-xs) 5px 0;background-color: transparent;.op-field__left-icon {color: var(--op-search-left-icon-color);margin-right: var(--van-padding-base);.van-icon {font-size: var(--van-field-icon-size);}}}
    }.op-cell {display: flex;box-sizing: border-box;width: 100%;color: var(--van-cell-text-color);font-size: var(--van-cell-font-size);line-height: var(--van-cell-line-height);&__value {flex: 1;color: var(--van-cell-text-color);vertical-align: middle;word-wrap: break-word;}
    }.op-field {&__control {display: block;box-sizing: border-box;width: 100%;min-width: 0;margin: 0;padding: 0;border: 0;color: var(--van-field-input-text-color);line-height: inherit;text-align: left;background-color: transparent;resize: none;user-select: none;&::placeholder {color: var(--van-field-placeholder-text-color);}}&__body {display: flex;align-items: center;}&__right-icon {color: var(--van-field-right-icon-color);padding: 0 var(--van-padding-xs);line-height: inherit;flex-shrink: 0;}&__clear {color: var(--van-field-clear-icon-color);font-size: var(--van-field-clear-icon-size) !important;cursor: pointer;}
    }
    input {&::-webkit-search-decoration,&::-webkit-search-cancel-button,&::-webkit-search-results-button,&::-webkit-search-results-decoration {display: none;}
    }
    </style>
    

BEM 命名规范

定义

  • Bem是块(block) 、元素(element) 、修饰符(modifier)的简写
  • - 中划线:仅作为连字符使用,表示某个块或者某个子元素的多单词之间的连接记号
  • __ 双下划线:双下划线用来连接块和块的子元素
  • -- 双中划线:双中划线用来描述一个块或者块的子元素的一种状态

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/662769.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

儿童护眼台灯怎么选择?一文教你如何选择儿童护眼台灯

护眼台灯是家长最常为孩子购买的用品之一&#xff0c;但是大部分人对它的了解并不多&#xff0c;很多人购买之后反而会觉得眼睛更容易疲劳&#xff0c;有不适的情况&#xff01;最主要的原因是因为挑选的台灯不够专业&#xff0c;次要原因则是使用方法不正确。所以今天跟大家讲…

yyyy与YYYY、dd与DD、mm与MM、hh与HH的区别

yyyy与YYYY、dd与DD、mm与MM、hh与HH的区别: Date now = new Date(); // 2024-02-02 14:26:xx、Fri Feb 02 14:26:xx CST 2024小写y是指Year、大写Y是指Week year(Week year是当天所在的周属于的年份,一周从周日开始,周六结束,只要本周跨年,那么这周就算入下一年) Sys…

Android.bp入门指南之浅析Android.bp文件

文章目录 Android.bp文件是什么&#xff1f;Android.bp的主要作用模块定义依赖关系构建规则模块属性插件支持模块的可配置性 为什么会引入Android.bp语法例子 Android.bp文件是什么&#xff1f; Android.bp 文件是 Android 构建系统&#xff08;Android Build System&#xff…

JavaScript基础五对象 内置对象 Math.random()

内置对象-生成任意范围随机数 Math.random() 随机数函数&#xff0c; 返回一个0 - 1之间&#xff0c;并且包括0不包括1的随机小数 [0, 1&#xff09; 如何生成0-10的随机数呢&#xff1f; Math.floor(Math.random() * (10 1)) 放大11倍再向下取整 如何生成5-10的随机数&…

科普类——进行基线设计、系统测试和优化的立体视觉软件与工具(七)

科普类——进行基线设计、系统测试和优化的立体视觉软件与工具&#xff08;七&#xff09; 在立体视觉领域&#xff0c;有许多立体视觉软件和工具可以帮助工程师进行基线设计、系统测试和优化。以下是一些常用的立体视觉软件和工具&#xff1a; Meshroom&#xff1a;这是一个基…

element-ui icon 组件源码分享

今日简单分享 element-ui 源码中的 icon 组件&#xff0c;主要从以下两个方面来分享&#xff1a; 一、源码中 icon 设计思想是什么呢&#xff1f;主要从页面结构、数据、 icon 样式三个方面来分享。 1.1 源码中 icon 组件的页面结构&#xff0c;可以在 package 目录下找到 ico…

python爬虫实战——获取酷我音乐数据

嗨喽&#xff0c;大家好呀~这里是爱看美女的茜茜呐 开发环境: 版 本&#xff1a; python 3.8 编辑器&#xff1a;pycharm 2022.3.2 模块使用: requests >>> pip install requests 如何安装python第三方模块: win R 输入 cmd 点击确定, 输入安装命令 pip install…

k8s kubeadm部署安装详解

目录 kubeadm部署流程简述 环境准备 步骤简述 关闭 防火墙规则、selinux、swap交换 修改主机名 配置节点之间的主机名解析 调整内核参数 所有节点安装docker 安装依赖组件 配置Docker 所有节点安装kubeadm&#xff0c;kubelet和kubectl 定义kubernetes源并指定版本…

【Java】【SSE】【VUE】实现调用千帆大模型,实现打字效果

没有废话。只有演示、和源码地址 效果演示 源码地址 qianfan-sse-demo: 基于https://gitee.com/codinginn/chatgpg-sse-demo-springboot-vue改动

Vue入门基础语法概要

文章目录 一、Vue框架基础语法vue文件构成 二、脚手架执行流程三、vue组件四、css样式写法其他实例以及解释&#xff0c;随便写写 一、Vue框架基础语法 el挂载点data数据对象标签 V-text 纯文本V-html 解析htmlV-on&#xff08;可替换为&#xff09; 为元素绑定事件&#xff0…

QT SQL

QT SQL模块提供数据库编程的支持&#xff0c;支持多种常见的数据库&#xff1a;MySQL\Oracle\MS SQL Server\SQLite等。SQL模块包含多个类&#xff0c;可以实现&#xff1a;数据库连接、SQL语句执行、数据获取与界面显示 等功能。数据 与 界面间用Model\View架构。 一、 二、Q…

FullStack之Django(2)模型和后台

FullStack之Django(2)模型和后台 author: Once Day date:2022年2月13日/2024年1月31日 漫漫长路&#xff0c;才刚刚开始… 全系列文档请查看专栏: FullStack开发_Once_day的博客-CSDN博客Django开发_Once_day的博客-CSDN博客 参考文档: 编写你的第一个 Django 应用&#…

docker安装定制gocd-agent

一、定制gocd-agent FROM gocd/gocd-agent-alpine-3.12:v21.1.0 MAINTAINER xxx "xxx163.com" # 切换到 root 用户 USER root # 安装 expect、jdk、docker RUN apk update && apk add expect && apk add openjdk8 && apk add docker &&…

Vue3的 组件事件

目录 介绍 触发与监听事件 事件参数 声明触发的事件 事件校验 总结 介绍 Vue3是Vue框架的最新版本&#xff0c;其中对组件事件进行了一些改进和优化。组件事件是Vue中一种常用的通信机制&#xff0c;用于在组件之间传递数据或触发动作。 Vue3中的组件事件主要有两种类型…

Spring Bean 定义常见错误

Spring 的核心是围绕 Bean 进行的。不管是 Spring Boot 还是 Spring Cloud&#xff0c;只要名称中带有 Spring 关键字的技术都脱离不了 Bean&#xff0c;而要使用一个 Bean 少不了要先定义出来&#xff0c;所以定义一个 Bean 就变得格外重要了。 当然&#xff0c;对于这么重要…

IntelliJ IDEA for mac的自定义快捷键

//0. 打开配置项command , //1. 自动修复错误快捷键&#xff0c;根据不同的语境建议不同的操作&#xff0c;比如对象变量的创建&#xff0c;引入类等option 回车 //2. 用来添加添加构造器&#xff0c;setter and getter, override&#xff0c;toString&#xff0c;给光标所…

Three.js PBR 物理渲染

详解 Three.js PBR 物理渲染 Three.js 是一个流行的基于 WebGL 的 JavaScript 库&#xff0c;专门用于创建和运行三维动画和游戏。其中很关键的一部分是物理渲染&#xff08;PBR&#xff09;。本文将深入探讨 Three.js 的 PBR 渲染&#xff0c;并为初学者提供实用的指导。 什…

2024人工智能可以报考的证书有哪些

人工智能&#xff08;AI&#xff09;是致力于解决通常与人类智能相关联的认知性问题的计算机科学领域&#xff0c;这些问题包括学习、创造和图像识别等。 关键的人工智能技术有哪些&#xff1f; 深度学习神经网络构成了人工智能技术的核心。神经网络反映了人脑中发生的过程。大…

JOSEF约瑟 HRTH-Y-2H2D跳位合位 电源监视继电器 导轨安装

HRTH-Y-2H2D跳位合位 电源监视继电器&#xff1a; HRTH-Y-2H2D-X-T&#xff1b;HRTH-Y-2Z-X-T&#xff1b;HRTH-Y-2H-X-T&#xff1b; HRTH-J-2H2D-X-T&#xff1b;HRTH-J-2Z-X-T;HRTH-J -2H-X-T&#xff1b; HRTH-Y-2H2D&#xff1b;HRTH-Y-2Z&#xff1b;HRTH-Y-2H&#xff1…

遇到ubuntu设置交叉编译环境的问题

今天交叉编译器一直没安装成功&#xff0c;环境变量也配置了还是不对&#xff0c;最后发现Ubuntu是64位的要装 然后就好了 另外在进行嵌入式Linux开发的时候&#xff0c;要把主机、虚拟机、以及开发板设置在同一网段下&#xff0c;虚拟机一般设成临时的就可以&#xff0c;但是…