IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> JavaScript知识库 -> vue获取循环dom节点 -> 正文阅读

[JavaScript知识库]vue获取循环dom节点

<template>
  <div v-for="(item, i) in programmeList" :key="item" class="special-l-one">
    <span
      class="special-l-one-name"
      :ref="
          (el) => {
            if (el) specialNameArray[i] = el;
          }
        "
    >
      {{ item.name }}
    </span>
  </div>
</template>

<script setup lang="ts" name="componentA">
  import { computed, onMounted, onBeforeUpdate, ref } from 'vue';
  const props = defineProps({

    programmeLists: {
      type: Array,
      required: true,
    },
    qualificationLists: {
      type: Array,
      required: true,
    },
    activityLists: {
      type: Array,
      required: true,
    },
  });

  const specialNameArray = ref([]); //特训任务下每个的 文字长度是否溢出一行,更换底图背景
 
  // 确保在每次更新之前重置ref
  onBeforeUpdate(() => {
    specialNameArray.value = [];
  });
  const programmeList = computed(() => props.programmeLists);
  const qualificationList = computed(() => props.qualificationLists);
  const activityList = computed(() => props.activityLists);

  onMounted(() => {
    
      for (var i = 0; i < specialNameArray.value.length; i++) {
        programmeList.value.clientHeight = specialNameArray.value[i].clientHeight;
      }
      programmeList.value.map((item, index) => {
        //把每个特训任务高度传入数组中记录高度 使用 大地图还是小底图
        item.clientHeight = specialNameArray.value[index].clientHeight;
      });
  });
</script>

在这里插入图片描述
这里我是想找到该节点的clientHeight高度,然后判断一行还是两行文字,不用行数,展示的背景图不同。所以这里把高度再遍历到数组里
在这里插入图片描述


上面为一维数组 找节点的方法。

然后如果是二维数组,也是同理

<template>
  <div
    class="special-box"
    :style="{
      height: specialHValue
        ? activityList.length <= 1
          ? specialHValue + 60 + 'px'
          : specialHValue + 'px'
        : specialRHeight + 'px',
    }"
  >
    <div
      class="special-l"
      ref="specialH"
      :style="{
        height: specialHValue + 'px',
        width:
          activityList[1].clientWidth > 443
            ? activityList[1].clientWidth + 20 + `px`
            : `443px`,
      }"
    >
      <div v-for="(item, i) in activityList" :key="item" class="special-l-one">
        <div class="special-task-comb-inner-box-middle-top">
          <div
            class="special-task-comb-inner-box-middle-top-one"
            :ref="
              (el) => {
                if (el) activityNameWidthArr[i] = el;
              }
            "
          >
            <div class="special-task-comb-inner-box-middle-top-l"></div>
            <div class="special-task-comb-inner-box-middle-top-m">
              <img
                class="icon_l"
                src="/src/assets/svg/careerMap/special_l.svg"
                alt=""
              />
              <span>{{ item?.name }}</span>
              <img
                class="icon_r"
                src="/src/assets/svg/careerMap/icon_tip.svg"
                alt=""
                @click="showModal(item)"
              />
            </div>
            <div class="special-task-comb-inner-box-middle-top-r"></div>
          </div>
          <div
            class="special-task-comb-inner-box-middle-top-two"
            :ref="
              (el) => {
                if (el) activityNameWidthArrTwo[i] = el;
              }
            "
          >
            <div class="special-task-comb-inner-box-middle-top-two-l"></div>
            <div class="special-task-comb-inner-box-middle-top-two-m">
              时长:{{ item?.duration }}
            </div>
            <div class="special-task-comb-inner-box-middle-top-two-r"></div>
          </div>
        </div>
        <template
          v-for="(itemSpecial, idx) in item.programmeList"
          :key="itemSpecial"
        >
          <div
            :class="
              itemSpecial.clientHeight1 <= 30
                ? `special-l-one-sm`
                : `special-l-one-big`
            "
            :style="{
              marginBottom: idx + 1 === programmeList.length ? `0` : `20px`,
            }"
          >
            <span
              class="special-l-one-name"
              :ref="
                (el) => {
                  if (el) specialNameArray1[[i, idx]] = el;
                }
              "
            >
              {{ itemSpecial.name }}{{ itemSpecial.clientHeight1 }}
            </span>
            <span class="special-l-one-time">
              ({{ itemSpecial.duration }}) {{ idx % 4 }}{{ 4 % 4 }}{{ 4 / 4
              }}{{ 0 / 4 }}
            </span>
            <div
              class="special-l-one-icon"
              :style="{
                top: itemSpecial.clientHeight1 <= 30 ? `-11px` : `1px`,
              }"
            ></div>
          </div>
        </template>
      </div>
    </div>
  </div>
</template>

<script setup lang="ts" name="componentA">
  import { computed, onMounted, onBeforeUpdate, ref } from "vue";

  const props = defineProps({
    programmeLists: {
      type: Array,
      required: true,
    },
    qualificationLists: {
      type: Array,
      required: true,
    },
    activityLists: {
      type: Array,
      required: true,
    },
  });
  const specialH = ref(); //记录左侧 特训列表高度
  const specialHValue = ref();
  const specialNameArray = ref([]); //特训任务下每个的 文字长度是否溢出一行,更换底图背景
  const specialNameArray1 = ref([]);
  // 确保在每次更新之前重置ref
  onBeforeUpdate(() => {
    specialNameArray.value = [];
  });
  const programmeList = computed(() => props.programmeLists);
  const qualificationList = computed(() => props.qualificationLists);
  const activityList = computed(() => props.activityLists);
  const specialR = ref();
  const specialRHeight = ref();
  const activityNameWidthArr = ref([]);
  const activityNameWidthArrTwo = ref([]);

  onMounted(() => {
    specialHValue.value =
      activityList.value.length <= 1
        ? specialH.value.clientHeight - 60
        : specialH.value.clientHeight - 90;
    specialRHeight.value = specialR.value.clientHeight;

    
    activityList.value.map((item, index) => {
      item.clientWidth =
        activityNameWidthArr.value[index].clientWidth +
        activityNameWidthArrTwo.value[index].clientWidth;
      item.programmeList.map((item1, idx) => {
        item1.clientHeight1 =
          specialNameArray1.value[[index, idx]].clientHeight;
      });
    });
  });
</script>

  JavaScript知识库 最新文章
ES6的相关知识点
react 函数式组件 & react其他一些总结
Vue基础超详细
前端JS也可以连点成线(Vue中运用 AntVG6)
Vue事件处理的基本使用
Vue后台项目的记录 (一)
前后端分离vue跨域,devServer配置proxy代理
TypeScript
初识vuex
vue项目安装包指令收集
上一篇文章      下一篇文章      查看所有文章
加:2022-05-14 09:51:44  更:2022-05-14 09:51:47 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 -2025/1/11 5:59:17-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码