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

asp网站怎样做app网站建设主要内容

asp网站怎样做app,网站建设主要内容,营销网站,网站建设的可行性v-lazyImg 在 Vue 3 中,可以通过自定义指令来实现v-lazyImg 功能 新建一个名为 lazyImg.ts 的文件,在其中定义一个名为 lazyImg 的自定义指令。 import type { Directive, DirectiveBinding ,App} from vue import errorImg from ./errorSrc.png // 导…

v-lazyImg

在 Vue 3 中,可以通过自定义指令来实现v-lazyImg 功能
  • 新建一个名为 lazyImg.ts 的文件,在其中定义一个名为 lazyImg 的自定义指令。
import type { Directive, DirectiveBinding ,App} from 'vue'
import errorImg from './errorSrc.png' // 导入默认错误图片// 交互动画选项配置
let options: {root: HTMLElement | nullthreshold: number
} | null// 交互动画实例
let observer: IntersectionObserver | null = null// 交互动画回调函数,用于处理图片懒加载逻辑
const callback: IntersectionObserverCallback = (entries) => {entries.forEach((entry) => {if (entry.isIntersecting) { // 判断元素是否进入视口const target = entry.target as HTMLImageElement // 获取目标元素(图片let img = target.dataset.src || '' // 从 data-src 属性获取图片真实地址// 图片加载函数const loadImage = (url: string) => {const image = new Image() image.src = url// 图片加载成功image.onload = () => {console.log('图片加载成功');   target.src = urlobserver?.unobserve(target)}// 图片加载失败image.onerror = () => {target.src = errorImgobserver?.unobserve(target)console.log('图片加载失败')}}loadImage(img)}})
}
// 观察处理函数,用于处理指令绑定逻辑
const observerHandler: (el: Element, binding: DirectiveBinding) => void = (el,binding,
) => {if (el.tagName !== 'IMG')returnconst { value } = binding // 获取指令绑定的值el.setAttribute('data-src', String(value)) // 将图片地址存储在 data-src 属性中observer?.observe(el)  // 开始观察元素
}// Vue 自定义指令对象,用于实现图片懒加载功能
const vImgLazyLoad: Directive = {// 在组件卸载前移除观察器,避免内存泄漏beforeUnmount(el: HTMLElement) {if (observer)observer.unobserve(el)},// 在指令绑定到元素时初始化观察器并开始观察mounted(el: HTMLElement, binding:DirectiveBinding) {if (options === null) {options = {root: document.querySelector('html'),  // 视口参考元素threshold: 0.1,  // 元素进入视口 10% 时触发回调}}if (observer === null)  // 创建交互动画实例observer = new IntersectionObserver(callback, options)observerHandler(el, binding)},// 在指令绑定值更新时重新绑定观察逻辑updated(el: HTMLElement, binding: DirectiveBinding) {observerHandler(el, binding)},
}
// 导出函数用于在 Vue 应用中注册指令
export const setupLazyImgDirective = (app: App<Element>) => {app.directive('lazyImg', vImgLazyLoad)}
export default vImgLazyLoad
  • 在 main.ts 中导入directive/index.ts并注册指令。
// directive/index.ts
import type { App } from 'vue'
import {setupLazyImgDirective} from './lazyImg'/*** 导出指令:v-xxx* @methods lazyImg 懒加载图片,用法: v-lazyImg="xxx"*/export const setupPermission = (app: App<Element>) => {setupLazyImgDirective(app)
}
  • vue 组件中中使用
<script setup lang="ts">import {ref} from "vue";const list = Array.from({ length: 100 }).map((_, i) => ({id: i,img: 'https://img1.baidu.com/it/u=837510728,3756639739&fm=253&fmt=auto&app=138&f=JPEG?w=800&h=800'}))
</script><template><imgv-for="item in list":key="item.id"v-lazyImg="item.img":style="{ width: '100px', height: '100px', display: 'block' }"/>
</template>
http://www.dtcms.com/wzjs/802944.html

相关文章:

  • 秦皇岛手机网站建设美叶设计网站
  • 网站建设销售培训语山西微网站建设
  • 电子元器件外贸网站建设网站制作2007
  • 自己建网站怎么做seo做的网站在百度找不到
  • 做网站网络wordpress首页等待画面
  • 做外贸纱线用什么网站百度上线wordpress结构化数据插件
  • 网站后台常用密码开发app费用一览表
  • 做资料上哪个网站好腾讯云服务器 学生
  • 初级网站开发的自我推荐盘锦威旺做网站
  • 广安网站制作设计东莞最新招聘
  • 网站开发宣传图片拉丝机东莞网站建设
  • 广西网站建设哪家不错电商网站硬件配置
  • app开发网站开发教程怎么制作图片模板
  • 自己有域名怎么做免费网站企业服务平台公众号
  • 内江建网站golang和php 做网站
  • 网站建设之开展电子商务公司简介模板免费图片
  • 计划网站搭建微信小程序怎么做网站
  • 百度网站建立广东建设信息网安管人员系统
  • 导购网站怎么做的seo代运营公司
  • php做网站用什么软件好沈阳建设工程信息网官网 安全中项网
  • 有没有找客户的网站重庆网站建设外包公司排名
  • 网站开发工具的功能包括哪些天津百度整站优化服务
  • 网页设计培训心得体会产品seo是什么意思
  • 贵州企业网站建设什么网站可以做旅行行程
  • 游戏设计师网站什么样的网站利于优化
  • 网站建设地域名建一个多用户团购网站需要多少钱
  • dedecms学校网站商业模式包括哪些模式
  • 五合一小程序网站付费阅读wordpress主题
  • 网站建设教程百度网盘搜索引擎网络推广方法
  • 网站用图片东莞人力资源招聘官网