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

dede 手机网站模板南京历史文化网页设计

dede 手机网站模板,南京历史文化网页设计,网页设计与制作(第2版)课件,网络品牌推广怎么做场景和指令用法 场景:电商网站的首页通常会很长,用户不一定能访问到页面靠下面的图片,这类图片通过懒加载优化手段可以做到只有进入视口区域才发送图片请求 核心原理:图片进入视口才发送资源请求 首先:我们需要定义一个全局的指令&#x…

场景和指令用法

场景:电商网站的首页通常会很长,用户不一定能访问到页面靠下面的图片,这类图片通过懒加载优化手段可以做到只有进入视口区域才发送图片请求

核心原理:图片进入视口才发送资源请求

首先:我们需要定义一个全局的指令,vue3官方的实现方法是这样的

第一步:熟悉指令语法

并且:还需要用到一个钩子函数

第二步:判断图片是否进入视口

我们可以使用useIntersectionObserver这个函数

以下是官方示例的使用方法:

<script setup lang="ts">
import { useIntersectionObserver } from '@vueuse/core'const { stop } = useIntersectionObserver(target,([entry], observerElement) => {targetIsVisible.value = entry?.isIntersecting || false},
)
</script>

target:需要监听的元素

isIntersecting:是一个布尔值 监听是否进入可视区

以下是完整代码实现

main.js

import { useIntersectionObserver } from '@vueuse/core'
const app = createApp(App)
// 定义全局指令
app.directive('img-lazy', {mounted(el, binding) {// el: 指令绑定的元素// binding: binding.value 指令的绑定值 图片urlconsole.log(el, binding.value);useIntersectionObserver(el, // 监听的元素([{ isIntersecting }]) => { // isIntersecting是一个布尔值 监听是否进入可视区console.log(isIntersecting);       if (isIntersecting) {// 图片进入可视区 设置图片的srcel.src = binding.value}})}
})

在需要懒加载的图片标签里使用这个即可

<img v-img-lazy="item.picture"  alt="" />

页面效果

由上图可以看出在刚进入页面时需要懒加载的图片没有加载出来

由上图可以看出当页面滑动到人气推荐时url全部都加载出来了

回顾核心步骤代码

================================补档优化==================================

问题1:逻辑书写位置不合理
问:懒加载指令的逻辑直接写到入口文件中,合理吗?

答:不合理,入口文件通常只做一些初始化的事情,不该包含太多的逻辑代码,可以通过插件的方法把懒加载指令封装为插件,main.js入口文件只需要负责注册插件即可

代码实现:

插件代码

// 定义懒加载指令
import { useIntersectionObserver } from '@vueuse/core'export const lazyPlugin = {install(app) {app.directive('img-lazy', {mounted(el, binding) {// el: 指令绑定的元素// binding: binding.value 指令的绑定值 图片urlconsole.log(el, binding.value);useIntersectionObserver(el, // 监听的元素([{ isIntersecting }]) => {// isIntersecting是一个布尔值 监听是否进入可视区console.log(isIntersecting);if (isIntersecting) {// 图片进入可视区 设置图片的srcel.src = binding.value}})}})}
}

main.js

// 引入懒加载指令并且注册
import { lazyPlugin } from '@/directives'
app.use(lazyPlugin)

问题2:重复监听问题
uselntersectionObserver对于元素的监听是一直存在的,除非手动停止监听,存在内存浪费
解决思路:在监听的图片第一次完成加载之后就停止监听

代码实现:

// 定义懒加载指令
import { useIntersectionObserver } from '@vueuse/core'export const lazyPlugin = {install(app) {app.directive('img-lazy', {mounted(el, binding) {// el: 指令绑定的元素// binding: binding.value 指令的绑定值 图片urlconsole.log(el, binding.value);const {stop} =  useIntersectionObserver(el, // 监听的元素([{ isIntersecting }]) => {// isIntersecting是一个布尔值 监听是否进入可视区console.log(isIntersecting);if (isIntersecting) {// 图片进入可视区 设置图片的srcel.src = binding.valuestop()}})}})}
}

http://www.dtcms.com/wzjs/545995.html

相关文章:

  • 简述企业网站维护的重要性wordpress根据分类id
  • 捷讯官网 网站建设怎么创立自己的网站
  • 建设网站号码是多少钱添加图标wordpress
  • 济南微网站开发凡科做的网站能被收录吗
  • 建设网站如何盈利企业网站和展板建设
  • 溧阳企业网站建设价格湖南网络推广服务平台
  • wordpress图片链接到附件网站优化新闻
  • 徐州做网站暖色调 网站
  • 基本的网站开发技术路线asp网站时间代码
  • 营业执照申请网站开一个建筑公司容易吗
  • 上海 餐饮网站建设网站宣传高新技术企业
  • 宁德做网站公司wordpress 菜单效果
  • 销售型网站建设基本要素淄博物联网app开发公司
  • title:网站建设公司实力杭州尚层别墅装饰公司
  • 陕西省城乡建设学校网站潍坊网站建设壹品网络
  • 怎样提升网站流量青岛品牌网站建设价格
  • 小视频做网站怎么赚钱吗移动商城型网站开发
  • 厦门路桥建设集团有限公司网站赣州网站开发制作
  • 做网站的软件是什么头像设计制作网站
  • 北京网站建设费用k5 wordpress主题
  • 网站如何做引流生鲜网站建设背景
  • 网站建设时间如何查询wordpress加底纹
  • 有哪些做图纸的网站做信息安全的网站
  • 网站专业制作公司徽与章网站建设宗旨
  • 石家庄小学网站建设中文wordpress博客模板
  • 网站首页设计有限公司设计一个学院网站
  • 东莞网站建设 石化wordpress文章postid
  • 那里可以做工作室做网站网页设计需要学什么学历
  • 龙华做棋牌网站建设哪家好成立公司法人有什么风险
  • 网站开发的技术支持外星人建设的网站