vue3知识点补充第二节

01  自定义Hook

正常的组件:<template><div><img id="img" src="./assets/images/01.png" width="300" height="300"></img></div></template><script>// 导入hook组件 并传递一个参数import userBase64 from './hooks'userBase64({el:'#img'}).then(res=>{console.log(res,'base64图片的地址')})    </script>Hook组件:import {onMounted} from 'vue'type Options = {el:string}export default function (el:OPtions):Promise<{naseUrl:string}> {return  new Promise(resolve=>{onMounted(()=>{let img:HTMLImgElement =  document.querySelector(options.el)img.onload = ()=>{resoleve({naseUrl:base64(img)})}})const base64 = (el:HTMLImageElement)=>{const canvas = document.createElement('canvas')const ctx = canvas.getContext('2d')canvas.height = el.heightcanvas.width = el.widthctx?.drawImage(el,0,0,canvas.width,canvas.height)return canvas.toDataURL('image/png')}})}

02 实现一个函数同时支持hook和自定义指令,去监听DOM宽高的变化

// interSectionObserver 主要监听元素是否在视口内// MutationObserver 主要监听子集的变化 属性的变化 以及增删改查// ResizeObserver  主要监听元素宽高的变化、、 创建hook函数function useResize (el:HTMLElement,callback:Function){let resize = new ResizeObserver((entries)=>{console.log(entries) // 监听所有元素 是一个数组callback(entries[0].contentRect) // 元素变化后的宽高都传递给这个函数})resize.observe (el)  // 监听的元素}、、 创建自定义指令import type {App} from 'vue'const install = (app:App)=>{app.directive('resize',{mounted(el,binding){useResize(el,binding.value)}})
}useResize.install = install

03 定义全局的变量或者函数并使用

定义全局的变量或者函数在main.ts文件中const app = createApp(app)app.config.globalProperties.$env = 'dev'使用的方法:在组件中直接使用就可以模板中直接使用 <div>{{$env}}</div>script中使用: const app = getCurrentInstance()console.log(app.proxy.$env)

04 css完整的特性:

01 插槽选择器:插槽组件:<template><div>我是插槽组件</div><div> <slot></slot> </div></template>父组件:<template><son><div class="a">传递给插槽的数据</div></son></template>出现的问题 : 在父组件定义插槽的内容 div类名为a的标签 如果想在插槽组件修改样式我无法修改的解决的办法 : 在插槽组件中使用插槽选择器 :slotted(.a){color:'red'} 就可以修改样式了02 全局选择器:如果在一个组件内想要给所有的div属性都绑定一个样式的话可以使用全局选择器<style scoped>:global(div){color:'red'
}</style>03 动态的css<template><div class="div">动态css</div></template><script>const style = ref('pink')</script><style>.div{color:v-bind(style)}</style>04 模块块化的css<div :class=[$style.div,$style.border]></div><style module>.div {color:'red'}.border{border:1px soild #ccc}</style>

05 tailwind/css的使用:

第一步 :初始化一个vue的项目:npm init vue@latest第二步 :安装vscode插件 tailwind css intelliSense 安装并启动第三步 安装相关依赖:npm install -D tailwindcss@latest postcss@latest autoprefixer@latest第四步 生成配置文件npm tailwindcss init -p第五步 修改配置文件 tailwind.config,js2.6版本:
module.exports ={purge:['./index.html','./src/**/*.{vue,js,ts,jsx,tsx}'],theme:{extend:{},},plugins: [],}3.0版本module.exports={content:./index.html',"./src/**/*.{vue,js,ts,jsx,tsx}'],theme:{extend:{}},plugins:[],}第六步 创建一个index.css@tailwindbase;@tailwindcomponents;@tailwindutilities;第七步 在main.ts文件中引入上面的index.css第八步 组件内部的标签就可以直接使用了<div class="w-screen h-screenbg-red-600 flex justify-center items-center text-8xltext-slate-200"></div>

05 关于nextTick

vue更新数据是同步的,但是vue更新DOM是异步:案例: 添加内容,屏幕出现滚动条,让每次添加的内容屏幕滚动都在最下面。const send = async ()=>{messageList.push('xiaoman') // 追加内容box.value.scrollTop = 99999999 // 卷去头部让其滚动到最下面问题:无法实现因为是异步的操作 // 第一种解决办法nextTick(()=>{box.value.scrollTop = 99999999 }) // 第二种办法 await nextTick()box.value.scrollTop = 99999999}原理 把我们的代码放到一个promise里面去执行, 执行的是then方法 走的是一个微任务


 

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

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

相关文章

【设计模式】六大设计原则

设计原则 研究 23 种设计模式是困难的&#xff0c;甚至是没必要的六大设计原则零、单一职责原则开闭原则里氏代换原则依赖倒置原则接口隔离原则迪米特法则合成复用原则 研究 23 种设计模式是困难的&#xff0c;甚至是没必要的 设计模式有23种&#xff0c;我认为对普通人来说想…

快速寻找可以构建出网通信隧道的计算机

点击星标&#xff0c;即时接收最新推文 本文选自《内网安全攻防&#xff1a;红队之路》 扫描二维码五折购书 为加强内网的安全防范&#xff0c;安全管理员往往会限制内网计算机访问互联网&#xff0c;当然不同机构的限制策略是不一样的&#xff0c;有的完全阻断了内网计算机访问…

如何发布自己的Python库?

Python包发布 1、背景概述2、操作指南 1、背景概述 为什么我们要发布自己的Python库&#xff1f;如果你想让你的Python代码&#xff0c;通过pip install xxx的方式供所有人下载&#xff0c;那就需要将代码上传到PyPi上&#xff0c;这样才能让所有人使用 那么&#xff0c;如何发…

Java基础知识总结(54)

&#xff08;1&#xff09; 手动实现LinkedList LinkedList底层结构实现和ArrayList底层数据结构实现有着本质上的区别 ArrayList底层实现主要依赖数组&#xff0c;而LinkedList底层实现则是依赖链表。 /** LinkedList的实现是双向链表&#xff0c;因此需要定义首节点和尾结点…

群晖双硬盘实时备份(WebDAV Server+Cloud Sync)

安装和设置 WebDAV Server WebDAV 是一种基于HTTP的协议扩展&#xff0c;它允许用户在远程Web服务器上进行文档的编辑和管理&#xff0c;就如同这些文件存储在本地计算机上一样。使用WebDAV&#xff0c;用户可以创建、移动、复制和修改文件和文件夹。 安装和设置 Cloud Sync…

2024/4/12 网络编程day2

OSI模型中的网络层次有哪些&#xff1f; 物理层&#xff0c;数据链路层&#xff0c;网络层&#xff0c;传输层&#xff0c;会话层&#xff0c;表示层&#xff0c;应用层TCP/IP协议族的分层有哪些&#xff1f; 网络接口层&#xff0c;网络层&#xff0c;运输层&#xff0c;应用层…

使用 Prometheus 在 KubeSphere 上监控 KubeEdge 边缘节点(Jetson) CPU、GPU 状态

作者&#xff1a;朱亚光&#xff0c;之江实验室工程师&#xff0c;云原生/开源爱好者。 KubeSphere 边缘节点的可观测性 在边缘计算场景下&#xff0c;KubeSphere 基于 KubeEdge 实现应用与工作负载在云端与边缘节点的统一分发与管理&#xff0c;解决在海量边、端设备上完成应…

前端面试问题汇总 - 浏览器篇

1. 本地存储有哪些&#xff0c;区别是什么&#xff1f; Cookies&#xff08;Cookie&#xff09;&#xff1a; 是存储在用户计算机上的小型文本文件&#xff0c;由网站服务器发送到用户的浏览器&#xff0c;然后在用户访问网站时由浏览器发送回服务器。Cookies 可以用来存储用户…

地球上四大洋介绍

地球上四大洋的分布是&#xff1a; 太平洋&#xff1a;太平洋是世界上最大的海洋&#xff0c;覆盖了约三分之一的地球表面。它位于亚洲、澳大利亚、美洲和南极洲之间。太平洋的面积约为1.6亿平方公里&#xff0c;拥有世界上最深的点——马里亚纳海沟。 大西洋&#xff1a;大西…

2024HW --> 安全产品 Powershell无文件落地攻击

在HW中&#xff0c;除了了解中间件&#xff0c;web漏洞&#xff0c;这些攻击的手法&#xff0c;还得了解应急响应&#xff0c;安全产品&#xff0c;入侵排查&#xff0c;溯源反制...... 那么今天&#xff0c;就来说一下安全产品&#xff08;安全公司我就不说了&#xff0c;这个…

ffmpeg cuda硬件解码后处理使用opengl渲染,全硬件流程

1 ffmpeg 硬件解码 使用硬件解码后不要transfer到内存&#xff0c;使用cuda转化nv12 -> bgr24 转化完毕后cuda里面存了一份bgr24 2 gpumat 和 cuda 互操作 如果需要opencv gpumat直接使用cuda内存&#xff0c;则可以手动构造gpumat 可以使用gpumat的各种函数 uchar3* cu…

6-139 大整数存储-数组

本题要求实现一个函数,实现大整数以整数形式存储。大整数按每4位保存在整数数组中,如果大整数位数不是4的倍数,则将保证低位都按4位一存。如“123456789”保存为1,2345,6789。大整数以字符串形式输入 int convert(char a[],int x[]); 函数接口定义: a 是以字符串形式输…

001vscode为什么设置不了中文?

VSCode中文插件安装 在VSCode中设置中文的首要步骤是安装“Chinese (Simplified) Language Pack for Visual Studio Code”扩展插件。这一过程十分简单&#xff0c;只需打开VSCode&#xff0c;进入扩展市场&#xff0c;搜索“ Chinese (Simplified) Language Pack ”然后点击…

【MATLAB源码-第49期】基于蚁群算法(ACO)算法的栅格路径规划,输出最佳路径图和算法收敛曲线图。

操作环境&#xff1a; MATLAB 2022a 1、算法描述 蚁群算法是一种模拟自然界蚂蚁觅食行为的启发式优化算法。在蚁群系统中&#xff0c;通过模拟蚂蚁之间通过信息素沟通的方式来寻找最短路径。 在栅格路径规划中&#xff0c;蚁群算法的基本步骤如下&#xff1a; 1. 初始化: …

MES实施优势有哪些?MES制造执行系统的主要内容

各个行业之间也开始进入到了激烈的竞争当中&#xff0c;很多企业为了能够有效提升企业竞争力&#xff0c;都会通过提升自身实力的方式来提升竞争力。一些制造业也会在经营过程当中使用到MES系统&#xff0c;那么&#xff0c;mes系统的优势有哪些呢&#xff1f; 1、优化企业现场…

mysql dump导出导入数据

前言 mysqldump是MySQL数据库中一个非常有用的命令行工具&#xff0c;用于备份和还原数据库。它可以将整个数据库或者特定的表导出为一个SQL文件&#xff0c;以便在需要时进行恢复或迁移。 使用mysqldump可以执行以下操作&#xff1a; 备份数据库&#xff1a;可以使用mysqld…

ELK日志分析系统+Filebeat

目录 一、Filebeat介绍 1、Filebeat简介 2、Filebeat的工作方式 3、filebeat工作流程 4、Filebeat的作用 5、filebeat的用途 1.为什么要用filebeat来收集日志&#xff1f;为什么不直接用logstash收集日志&#xff1f; 2.filebeat和logstash的区别 二、部署(ELFK)Fileb…

自动化测试Junit

1.什么是Junit JUint是Java编程语言的单元测试框架&#xff0c;用于编写和运行可重复的自动化测试。 JUnit 促进了“先测试后编码”TDD的理念&#xff0c;强调建立测试数据的一段代码&#xff0c;可以先测试&#xff0c;然后再应用。这个方法就好比“测试一点&#xff0c;编码一…

现在有一个二叉树, 父节点保存子节点字符总长度。

现在有一个二叉树&#xff0c; 父节点保存子节点字符总长度。 typedef struct Node{ char *data; struct Node* left; struct Node* rigth; int length; }Node,*tree; 写一个求substring的功能。 Now, if we call substring with lower idx2 and upper idx7, the first part ca…

【SERVERLESS】AWS Lambda上实操

通过Serverless的发展历程及带给我们的挑战&#xff0c;引出我们改如何改变思路&#xff0c;化繁为简&#xff0c;趋利避害&#xff0c;更好的利用其优势&#xff0c;来释放企业效能&#xff0c;为创造带来无限可能。 一 Serverless概述 无服务器计算近年来与云原生计算都是在…