欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

javaScript與vue獲取元素的方法代碼示例

 更新時間:2023年10月08日 11:56:35   作者:小宛碎碎冰  
在開發(fā)中我們可能會遇到這樣的問題,文本框聚焦、元素點擊等,所以下面這篇文章主要給大家介紹了關于javaScript與vue獲取元素的相關資料,需要的朋友可以參考下

javaScript

1 根據(jù)ID獲取

get 獲得 element 元素 by 通過

返回的是一個元素對象

document.getElementById('ID');

2 根據(jù)標簽名獲取

get 獲得 element 元素 by 通過 Tag標簽 Name名字

返回帶有指定標簽名的對象的集合 以偽數(shù)組的形式存儲

document.getElementsByTagName('標簽名');

3 通過HTML5新增的方法獲取

document.getElementsByClassName('類名') 需要加下標 因為class可以有多個元素

querySelector('?') 參數(shù)是css選擇器,只能返回一個元素(最上面的元素)

querySelectorAll('?') 參數(shù)是css選擇器,會返回全部該選擇器集合 通過下標獲取單個元素

vue獲取元素及兄弟元素,父級元素

先添加ref

<div class="" ref="divBox">

獲取對象

let a = this.$refs.divBox

獲取父、子、兄弟節(jié)點方法

var b = a.childNodes; 獲取a的全部子節(jié)點
var c = a.parentNode; 獲取a的父節(jié)點
var d = a.nextSbiling; 獲取a的下一個兄弟節(jié)點
var d = a.nextElementSibling; 獲取a的下一個兄弟節(jié)點
var e = a.previousSbiling;獲取a的上一個兄弟節(jié)點
var e = a.previousElementSibling;獲取a的上一個兄弟節(jié)點
var f = a.firstChild; 獲取a的第一個子節(jié)點
var g = a.lastChild; 獲取a的最后一個子節(jié)點

附:vue遍歷過程中獲取元素

在開發(fā)時遇到需要遍歷設備集合,并且一個集合對應一個視頻元素(video)的問題

這里主要展示vue遍歷過程中如何取出元素的方法以及一些坑

首先是循環(huán)

    <el-row style="margin-bottom: 10px;">
      <template v-for="(item, index) in equipmentTempList">
        <el-col :xs="24" :sm="24" :md="12" :lg="4">
          <el-card class="update-log">
            <el-row style="text-align: center; margin-bottom: 40px">實時溫度信息</el-row>
            <el-row style="height: 48px;">
              <el-col><span>當前相機精確位置:{{ item.groupName }}</span></el-col>
            </el-row>
            <el-row style="height: 48px;">
              <el-col><span>當前外表最低溫度:{{ item.tempMin }}℃</span></el-col>
            </el-row>
            <el-row style="height: 48px;">
              <el-col><span>當前外表最高溫度:{{ item.tempMax }}℃</span></el-col>
            </el-row>
            <el-row style="height: 48px;">
              <el-col><span>當前外表平均溫度:{{ item.tempAvg }}℃</span></el-col>
            </el-row>
          </el-card>
        </el-col>
        <el-col :xs="24" :sm="24" :md="12" :lg="8">
          <div style="height: 296px; width: 489px">
            <video :ref="'videoRef_' + index" :id="'video_' + index" height="285" width="400" muted="muted"
                   autoplay="autoplay"></video>
          </div>
        </el-col>
      </template>
    </el-row>

綁定ref元素是為了獲取video元素,并且由于是數(shù)組所以每一個video元素需要綁定給不同ref,總的來說如果你需要在組件的 JS 代碼中操作 <video> 元素,可以使用 ref 屬性,如果需要給 <video> 元素設置樣式或者 JS 代碼中無需操作該元素,可以使用 id 屬性。

 然后是method

    async mwfs() {
        // Wfs 對象已經(jīng)存在,可以進行后續(xù)操作
        if (Wfs.isSupported()) {
          // 循環(huán)遍歷設備列表
          //發(fā)送請求獲取當前設備列表
          this.equipmentList = await this.getEquipmentTemp()
          for (let i = 0; i < this.equipmentList.length; i++) {
            const item = this.equipmentList[i];
            // // 發(fā)送同步請求獲取當前溫度信息
            // const res = await EquipTemp(item);
            // this.equipmentTempList.push(res.data)
            // 使用異步操作加載視頻源
            await new Promise(async resolve => { // 將 Promise 函數(shù)添加 async 關鍵字標識
              //保證獲取最新的DOM元素
              this.$nextTick(() => {
                const videoRef = this.$refs[`videoRef_${i}`][0];
                console.log(videoRef)
                const wfs = new Wfs();
                wfs.attachMedia(videoRef, item.id);
                this.videos.push(wfs)
                wfs.on(Wfs.Events.MEDIA_ATTACHED, () => {
                  videoRef.play();
                  resolve();
                });
              });
            });
          }
      }
    },

在這段代碼中,首先是for循環(huán),為什么不采用foreach循環(huán)有以下原因

       ->首先就是先獲取了設備列表然后采用了異步操作加載視頻源可以避免阻塞主線程,提高頁面響應速度,并且在加載多個視頻時,異步操作可以同時進行,進一步提高效率。

       ->其次就是在foreach循環(huán)中無法等待異步操作完成再執(zhí)行下一步循環(huán)的問題,因此容易出現(xiàn)數(shù)據(jù)錯亂或者遺漏等問題。

       然后這里的this.$nextTick是為了保證我們的video元素已經(jīng)是最新的才進行視頻加載,獲取元素的方法是通過this.$refs[`videoRef_${i}`][0]獲取的,因為ref是可以綁定多個元素的,而我們是一個設備對應一個視頻的,所以只需要取ref數(shù)組的第一個元素即可。

tips:只需要將元素打印出來,如果不是undefined是對應的元素即為獲取到元素

總結

到此這篇關于javaScript與vue獲取元素的文章就介紹到這了,更多相關js與vue獲取元素內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!

您可能感興趣的文章:

相關文章

  • Vue3中Props和Emit的工作原理詳解

    Vue3中Props和Emit的工作原理詳解

    在現(xiàn)代前端開發(fā)中,Vue.js 來作為一個流行的 JavaScript 框架,提供了簡單易用的 API 和強大的功能,在 Vue 3 中,“Props”和“Emit”是兩個核心概念,本文將詳細探討這兩個概念的工作原理,并提供示例代碼以幫助更好地理解它們的使用,需要的朋友可以參考下
    2024-11-11
  • 如何利用vue展示.docx文件、excel文件和csv文件內(nèi)容

    如何利用vue展示.docx文件、excel文件和csv文件內(nèi)容

    最近遇到了一些新的需求,需要前端實現(xiàn)文件預覽功能,下面這篇文章主要給大家介紹了關于如何利用vue展示.docx文件、excel文件和csv文件內(nèi)容的相關資料,文中通過實例代碼介紹的非常詳細,需要的朋友可以參考下
    2023-04-04
  • 使用VUE+iView+.Net Core上傳圖片的方法示例

    使用VUE+iView+.Net Core上傳圖片的方法示例

    這篇文章主要介紹了使用VUE+iView+.Net Core上傳圖片的方法示例,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2019-01-01
  • Vue3?重構函數(shù)透傳示例解析

    Vue3?重構函數(shù)透傳示例解析

    這篇文章主要為大家介紹了Vue3?重構函數(shù)透傳示例解析
    2023-02-02
  • 分享Vue組件傳值的幾種常用方式(二)

    分享Vue組件傳值的幾種常用方式(二)

    這篇文章主要介紹了分享Vue組件傳值的幾種常用方式,文章圍繞主題斬開詳細的內(nèi)容介紹,具有一定的參考價值,需要的小伙伴可以參考一下
    2022-09-09
  • vue3?Table分頁保留選中狀態(tài)代碼示例

    vue3?Table分頁保留選中狀態(tài)代碼示例

    這篇文章主要給大家介紹了關于vue3?Table分頁保留選中狀態(tài)的相關資料,vue table組件是一個非常方便的表格組件,它可以幫助我們實現(xiàn)分頁和選中功能,需要的朋友可以參考下
    2023-08-08
  • 如何在JS文件中獲取Vue組件

    如何在JS文件中獲取Vue組件

    這篇文章主要介紹了如何在JS文件中獲取Vue組件,幫助大家更好的理解和學習前端知識,感興趣的朋友可以了解下
    2020-09-09
  • Vue自定義指令中無法獲取this的問題及解決

    Vue自定義指令中無法獲取this的問題及解決

    這篇文章主要介紹了Vue自定義指令中無法獲取this的問題及解決方案,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-08-08
  • Vue如何配置根目錄@(引用路徑)

    Vue如何配置根目錄@(引用路徑)

    這篇文章主要介紹了Vue如何配置根目錄@(引用路徑),具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-04-04
  • Vue 應用中結合vux使用微信 jssdk的方法

    Vue 應用中結合vux使用微信 jssdk的方法

    今天小編就為大家分享一篇Vue 應用中結合vux使用微信 jssdk的方法,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2018-08-08

最新評論