首页 > 其他分享 >vue3项目-小兔鲜儿笔记-首页03

vue3项目-小兔鲜儿笔记-首页03

时间:2022-08-30 00:35:05浏览次数:59  
标签:03 const target 鲜儿 result vue3 import ref 函数

1. 面板封装

提取首页的公用面板进行复用

  • 头部

    • 标题和副标题由props传入

    • 右侧内容由具名插槽right传入

      • 查看更多封装成全局组件

  • 主体

    • 由默认插槽传入

<template>
  <!-- 封装面板组件 -->
  <div class="home-panel">
    <div class="container">
      <div class="head">
        <h3>
          {{ title }}
          <small>{{ subTitle }}</small>
        </h3>
        <!-- 标题右侧具名插槽 -->
        <slot name="right"/>
      </div>
      <!-- 内容默认插槽 -->
      <slot/>
    </div>
  </div>
</template>

<script setup>
defineProps({
  title: {
    type: String,
    default: ''
  },
  subTitle: {
    type: String,
    default: ''
  }
})
</script>

 

2. 应用面板举例:新鲜好物

<template>
  <div class="home-new">
    <HomePanel title="新鲜好物" sub-title="新鲜出炉 品质靠谱">
      <!-- 右侧具名插槽使用查看更多组件 -->
      <template #right>
        <XtxMore />
      </template>
      <!-- 默认插槽传入主体内容 -->
      <template #default>
        <ul class="goods-list">
          <template v-if="goodsList.length">
            <li v-for="goods in goodsList" :key="goods.id">
              <router-link to="/">
                <img :src="goods.picture" alt="" />
                <div class="info">
                  <p class="name">{{ goods.desc }}</p>
                  <p class="price">¥{{ goods.price }}</p>
                </div>
              </router-link>
            </li>
          </template>
          <!-- 使用骨架屏处理数据正在加载的这段时间的显示 -->
          <template v-else>
            <li v-for="i in 4" :key="i">
              <XtxSkeleton width="306px" height="406px" />
            </li>
          </template>
        </ul>
      </template>
    </HomePanel>
  </div>
</template>

<script setup>
import HomePanel from '@/views/home/components/home-panel'
import { findNew } from '@/api/home'
import { ref } from 'vue'

const goodsList = ref([])
findNew().then((res) => {
  goodsList.value = res.result
})
</script>

 

3. 数据懒加载

目的:实现当组件进入可视区域时再加载数据

使用@vueuse/core中的useIntersectionObserver来实现监听元素进入可视区域的行为

函数的理解:

  • 函数返回一个stop函数,用于停止监听元素进入可视区域的行为

  • 函数传入两个参数

    • 参数一:target,是监听的目标元素

    • 参数二:callback函数,这个回调函数传入两个参数

      • 参数1:isIntersecting:是否进入可视区域,是布尔值,true是进入

      • 参数2:这里没有用到

封装数据懒加载函数:

import { useIntersectionObserver } from '@vueuse/core'
import { ref } from 'vue'
/**
 * 数据懒加载函数
 * @param {Element} target - 要观察的DOM对象
 * @param {Function} apiFn - 要执行的获取数据的函数
 */
export const useLazyData = (apiFn) => {
  const target = ref(null)
  const result = ref([])
  // stop 停止观察
  const { stop } = useIntersectionObserver(
    target, // 要监听的目标元素
    ([{ isIntersecting }], observerElement) => {
      // 如果元素已进入可视区域
      if (isIntersecting) {
        stop()
        // 调用api获取数据
        apiFn().then((res) => {
          result.value = res.result
        })
      }
    }
  )
  return {
    target,
    result
  }
}

使用时只需:
const {target, result} = useLazyData(apiFn) // 解构出来即可

 

标签:03,const,target,鲜儿,result,vue3,import,ref,函数
From: https://www.cnblogs.com/jzhFlash/p/16637902.html

相关文章

  • vue3 基础-事件绑定 & 修饰符
    无非就是js的一些事件,按键,鼠标等的一些绑定在vue的实现而已,很好理解.先来看一个基础例子.事件初体验<!DOCTYPEhtml><htmllang="en"><head><title>事......
  • React报错之Property 'value' does not exist on type EventTarget
    正文从这开始~总览当event参数的类型不正确时,会产生"Property'value'doesnotexistontypeEventTarget"错误。为了解决该错误,将event的类型声明为React.ChangeEvent......
  • 洛谷 P6862 [RC-03] 随机树生成器 绿 题解
    前言模数要模\(1e9+9\)!!模数要模\(1e9+9\)!!模数要模\(1e9+9\)!!结论\(n\)个点的树的形态有\((n-1)!\)个,对于节点\(k\),它的所有度数和为\((n-1)!\left(\sum\limits_{......
  • Day03下载配置java环境以及如何删除java文件
    卸载JDK删除java的安装目录删除JAVA_HOME删除path下关于java的目录java-version安装JDK百度搜索JDK8,找下载地址同意下载协议下载电脑对应版本......
  • vue3基础入门
    vue3基础入门官方网站:https://v3.vuejs.org/中文文档:https://staging-cn.vuejs.org/guide/introduction.html1、简介1.1、vue是什么?Vue.js(读音/vjuː/,类似于vi......
  • vue3+vuex 的 mutations 的 使用
    <template><divclass="app">姓名:{{$store.state.nameVuex}}<button@click="btn">基本方法:修改名字</button><br/><button@click="btn1">传递值......
  • 0032-Rust-自实现迭代器
    环境Time2022-05-21Rust1.61.0前言说明参考:https://doc.rust-lang.org/std/iter/index.html目标接前一节,在迭代的过程中,修改每个迭代的元素。自定义类型#[der......
  • 0033-Rust-实现递归迭代
    环境Time2022-05-21Rust1.61.0前言说明参考:https://fasterthanli.me/articles/recursive-iterators-rust目标对于递归类型的结构,实现递归迭代。自定义类型str......
  • Unrecognised input. Possibly missing opening '{'
    引入element-plus样式文件时报错Unrecognisedinput.Possiblymissingopening'{' 配置webpack时,如果是这样写的:css文件使用css-loader解析器修改 ......
  • vue3+vuex 的 getters 的 使用
     app.vue<template><divclass="app"><h3>在模板中直接使用(vue2-3都可用)</h3>计算:{{$store.getters.counterGetter}}<br/>年龄:......