使用JS的DOM(文檔對象模型)獲取前端迴圈的參數

来源:https://www.cnblogs.com/echoqiqi/archive/2023/02/11/17112628.html
-Advertisement-
Play Games

使用JS的DOM(文檔對象模型)獲取前端迴圈的參數 使用Go語言渲染html,但是想讓網頁動起來,顯示一些彈窗還是比較麻煩的,於是乎,想到使用js獲取頁面的數據進行顯示,但是js無法載入go的一些變數。想了很久,突然在網頁調試的時候使用了js的DOM進行元素查找獲得了些許靈感最後實現了這個功能。 1 ...


使用JS的DOM(文檔對象模型)獲取前端迴圈的參數

使用Go語言渲染html,但是想讓網頁動起來,顯示一些彈窗還是比較麻煩的,於是乎,想到使用js獲取頁面的數據進行顯示,但是js無法載入go的一些變數。想了很久,突然在網頁調試的時候使用了js的DOM進行元素查找獲得了些許靈感最後實現了這個功能。

1.網頁顯示部分

該部分是顯示go後端傳遞的一個結構體數組裡的各項數據,展示到一個表格中,故使用了迴圈展示數據,詳見代碼:

            {{ range $v := .res}}
                    <tr >
                            <td name="assetid">{{ $v.AssetUUID}}</td>
                            <td>{{ $v.AssetName}}</td>
                            <td>{{ $v.AssetPrice}}</td>
                            <td>{{$v.ProofUUID}}</td>
                            <td>{{ $v.DataType}}</td>
                            <td>{{ $v.DeviceType}}</td>
                            <td>{{ $v.StorageTime}}</td>
                            <td>
                                <a class="link-update" href="javascript:del($r)">撤銷</a>
                                <a class="link-update" href="#.html/?AssetID={{$v.AssetUUID}}">更新</a>
                            </td>
                        </tr>
                        {{ end }}

在代碼中的

{{ range $v := .res}}
.....
{{end}}

這個部分.res是Go後端向網頁傳遞的數據,range $v即是對其進行遍歷的操作。

撤銷操作使用get方法傳遞參數,但是再確定是否執行撤銷操作的時候,我想進行確認,因此需要獲得{{ $v.AssetUUID}}的數據,傳進js裡面,進行彈框的確定及URL的跳轉。

我嘗試,將{{ $v.AssetUUID}}當成變數直接傳進js里是執行不了的,這一步進行不下去了。

2.使用js的DOM獲取頁面的數據

 2.1預備知識

1)DOM查找元素

document獲取節點的基本方法

document.getElementById('id');  //通過id來獲取元素,返回指定的唯一元素。

document.getElementsByName("name"); //通過name來獲取元素,返回name='name'的集合。

.document.getElementsByClassName("classname")  //用classname來獲取元素,返回的是一個class="classname"的集合(不相容IE8及以下)。

document.getElementsByTagName('div'); //用元素的標簽獲取元素,返回所有標簽=“div”的集合。

2)  查找

直接查找

  var obj = document.getElementById('id');

間接查找

  文件內容操作

  innerText 僅文本

  innerHTML 全內容

  value

  input value 獲取當前的值

  select 獲取選中的value的值 document.getElementById('s1').selectedIndex=1

  Textarea 獲取value的值

2.2 從網頁獲取數據

 document.getElementsByName("assetid")獲得的是一個NodeList的列表

 

 如何獲得具體的assetid呢?

可以使用 document.getElementsByName("assetid")[]這種方式定位到需要獲得id的位置,比如獲得第一個assetid位置是: document.getElementsByName("assetid")[0]

且 document.getElementsByName("assetid")[0].textContent是這個數據裡面的text值,具體請看:

 

 即可獲取這個id的具體值。

代碼具體實現:

                        <script>
                            $r=-1;
                        </script>
                        {{ range $v := .res}}
                        <script>
                            $r++;
                        </script>
                        <tr >
                            <td name="assetid">{{ $v.AssetUUID}}</td>
                            <td>{{ $v.AssetName}}</td>
                            <td>{{ $v.AssetPrice}}</td>
                            <td>{{$v.ProofUUID}}</td>
                            <td>{{ $v.DataType}}</td>
                            <td>{{ $v.DeviceType}}</td>
                            <td>{{ $v.StorageTime}}</td>
                            <td>
                                <a class="link-update" href="javascript:del($r)">撤銷</a>
                                <a class="link-update" href="#.html/?AssetID={{$v.AssetUUID}}">更新</a>
                            </td>
                        </tr>
                        {{ end }} 

<script>
        function del(pos){
            if(false==confirm("是否確定刪除當前記錄")) return;
            var $aid=document.getElementsByName("assetid")[pos].textContent;
            location.href='Myasset.html/?action=del&AssetID='+$aid;
        }
    </script>                              

  說明$r表示的是下標。


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 前言 Web項目中很多網頁資源比如html、js、css通常會做伺服器端的緩存,加快網頁的載入速度 一些周期性變化的API數據也可以做緩存,例如廣告資源位數據,菜單數據,商品類目數據,商品詳情數據,商品列表數據,公共配置數據等,這樣就可以省去很多在服務端手動實現緩存的操作 最早資源緩存大部分都用Ex ...
  • 這是一個關於 ASP.NET 6 依賴註入的系列文章。 在這個系列中,我們將瞭解到什麼是依賴註入、控制反轉,它能夠做什麼,以及我們為什麼要使用它。 之後,我們會進一步瞭解 ASP.NET 6 依賴註入的生命周期、服務容器等重要概念。 最後,我們再深入瞭解服務作用域和更多的服務註冊與註入方式。 概述 ...
  • 設計原則系列文章 必知必會的設計原則——單一職責原則 必知必會的設計原則——開放封閉原則 必知必會的設計原則——依賴倒置原則 必知必會的設計原則——里氏替換原則 概述 1、 客戶端不應該依賴它不需要的介面。2、 一個類對另一個類的依賴應該建立在最小介面上。3、介面應儘量細分,不要在一個介面中放很多方 ...
  • 「CSDN」作為中國最具人氣的專業 IT 社區,一直是廣大 IT 技術博主的主選陣地。這些年 CSDN 在知識付費領域的探索也遠遠超過其它平臺,大家(尤其是創作型博主)對 CSDN 的認可度也越來越高,CSDN 上目前有很多非常優秀的技術專欄。 CSDN博客專家 是 CSDN 給予影響力較大的技術類 ...
  • 前言 AppImage 逐漸成為 Linux 常用的一種軟體包格式,本文將介紹如何將 AppImage 文件添加到 Ubuntu 的應用程式中。 如下圖中的 CAJViewer : 操作過程 設置相關許可權 對要操作的 AppImage 右擊 > 屬性進行如下圖的設置,必須勾選 允許執行文件 創建 d ...
  • JLink RTT(Real Time Transfer) 是用於嵌入式系統監控和交互的工具, 類似於SWO, 可以雙向通信, 特點是性能很高, 基本上不影響嵌入式應用的實時行為, 可以對比一下使用printf輸出日誌時的各種限制. 而且因為和 JLink 介面集成, 不需要再浪費一個串口輸出 pr... ...
  • PY32F002A, PY32F003, PY32F030 三個系列硬體相同, 下麵以 PY32F030的時鐘樹結構為例說明 內部時鐘有32KHz和24MHz(從代碼上看其實是8MHz),外部時鐘是直接接入, PLL只有2倍. 使用外置晶振時如果要達到標稱的48MHz, 晶振頻率就必須用24MHz,... ...
  • 為什麼會選擇Pop!_os 剛決定使用Linux系統的時候想的肯定是用Arch Linux(不得不說ArchWiki太NB了),但是遇到兩個麻煩沒有解決:1.連上wifi後發現沒有分配IPv4地址,google了一圈都沒找到解決方法。於是放棄了。2.第二次嘗試安裝Arch(主要是第一次安裝失敗後,心 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...