JS---DOM---課程中涉及到的common.js

来源:https://www.cnblogs.com/jane-panyiyun/archive/2019/12/11/12021837.html
-Advertisement-
Play Games

//格式化日期的代碼 //獲取指定標簽對象 //獲取元素的文本內容 //獲取元素的文本內容 //獲取父級元素中的第一個子元素 //獲取父級元素中的最後一個子元素 //獲取某個元素的前一個兄弟元素 //獲取某個元素的後一個兄弟元素 //獲取某個元素的所有兄弟元素 //返回當前瀏覽器是什麼類型的瀏覽器 ...



//格式化日期的代碼 //獲取指定標簽對象 //獲取元素的文本內容 //獲取元素的文本內容 //獲取父級元素中的第一個子元素 //獲取父級元素中的最後一個子元素 //獲取某個元素的前一個兄弟元素 //獲取某個元素的後一個兄弟元素 //獲取某個元素的所有兄弟元素 //返回當前瀏覽器是什麼類型的瀏覽器 //為任意一個元素綁定事件:元素,事件類型,事件處理函數 //為任意的一個元素解綁某個事件:元素,事件類型,事件處理函數

/**
 * 格式化日期
 * @param dt 日期對象
 * @returns {string} 返回值是格式化的字元串日期
 */
function getDates(dt) {
    var str = "";//存儲時間的字元串
    //獲取年
    var year = dt.getFullYear();
    //獲取月
    var month = dt.getMonth() + 1;
    //獲取日
    var day = dt.getDate();
    //獲取小時
    var hour = dt.getHours();
    //獲取分鐘
    var min = dt.getMinutes();
    //獲取秒
    var sec = dt.getSeconds();
    month = month < 10 ? "0" + month : month;
    day = day < 10 ? "0" + day : day;
    hour = hour < 10 ? "0" + hour : hour;
    min = min < 10 ? "0" + min : min;
    sec = sec < 10 ? "0" + sec : sec;
    str = year + "年" + month + "月" + day + "日 " + hour + ":" + min + ":" + sec;
    return str;
}
/**
 * 獲取指定標簽對象
 * @param id 標簽的id屬性值
 * @returns {Element}根據id屬性值返回指定標簽對象
 */
function my$(id) {
    return document.getElementById(id);
}

function setInnerText(element, text) {
    if (typeof element.textContent == "undefined") {
        element.innerText = text;
    } else {
        element.textContent = text;
    }
}
/**
 * 獲取元素的文本內容
 * @param element 任意元素
 * @returns {*} 任意元素中的文本內容
 */
function getInnerText(element) {
    if (typeof (element.textContent) == "undefined") {
        return element.innerText;
    } else {
        return element.textContent;
    }
}
/**
 * 獲取父級元素中的第一個子元素
 * @param element 父級元素
 * @returns {*} 父級元素中的子級元素
 */
function getFirstElement(element) {
    if (element.firstElementChild) {
        return element.firstElementChild;
    } else {
        var node = element.firstChild;
        while (node && node.nodeType != 1) {
            node = node.nextSibling;
        }
        return node;
    }
}
/**
 * 獲取父級元素中的最後一個子元素
 * @param element 父級元素
 * @returns {*} 最後一個子元素
 */
function getLastElement(element) {
    if (element.lastElementChild) {
        return element.lastElementChild;
    } else {
        var node = element.lastChild;
        while (node && node.nodeType != 1) {
            node = node.previousSibling;
        }
        return node;
    }
}
/**
 * 獲取某個元素的前一個兄弟元素
 * @param element 某個元素
 * @returns {*} 前一個兄弟元素
 */
function getPreviousElement(element) {
    if (element.previousElementSibling) {
        return element.previousElementSibling
    } else {
        var node = element.previousSibling;
        while (node && node.nodeType != 1) {
            node = node.previousSibling;
        }
        return node;
    }
}
/**
 * 獲取某個元素的後一個兄弟元素
 * @param element 某個元素
 * @returns {*} 後一個兄弟元素
 */
function getNextElement(element) {
    if (element.nextElementSibling) {
        return element.nextElementSibling
    } else {
        var node = element.nextSibling;
        while (node && node.nodeType != 1) {
            node = node.nextSibling;
        }
        return node;
    }
}
/**
 * 獲取某個元素的所有兄弟元素
 * @param element 某個元素
 * @returns {Array} 兄弟元素
 */
function getSiblings(element) {
    if (!element) return;
    var elements = [];
    var ele = element.previousSibling;
    while (ele) {
        if (ele.nodeType === 1) {
            elements.push(ele);
        }
        ele = ele.previousSibling;
    }
    ele = element.nextSibling;
    while (ele) {
        if (ele.nodeType === 1) {
            elements.push(ele);

        }
        ele = ele.nextSibling;
    }
    return elements;
}
/**
 * 返回當前瀏覽器是什麼類型的瀏覽器
 */
function userBrowser() {
    var browserName = navigator.userAgent.toLowerCase();
    if (/msie/i.test(browserName) && !/opera/.test(browserName)) {
        console.log("IE");
    } else if (/firefox/i.test(browserName)) {
        console.log("Firefox");
    } else if (/chrome/i.test(browserName) && /webkit/i.test(browserName) && /mozilla/i.test(browserName)) {
        console.log("Chrome");
    } else if (/opera/i.test(browserName)) {
        console.log("Opera");
    } else if (/webkit/i.test(browserName) && !(/chrome/i.test(browserName) && /webkit/i.test(browserName) && /mozilla/i.test(browserName))) {
        console.log("Safari");
    } else {
        console.log("不知道什麼鬼!");
    }
}



//為任意一個元素綁定事件:元素,事件類型,事件處理函數
function addEventListener(element, type, fn) {
    if (element.addEventListener) {
        //支持
        element.addEventListener(type, fn, false);
    } else if (element.attachEvent) {
        element.attachEvent("on" + type, fn);
    } else {
        element["on" + type] = fn;
    }
}
//為任意的一個元素解綁某個事件:元素,事件類型,事件處理函數
function removeEventListener(element, type, fn) {
    if (element.removeEventListener) {
        element.removeEventListener(type, fn, false);
    } else if (element.detachEvent) {
        element.detachEvent("on" + type, fn);
    } else {
        element["on" + type] = null;
    }
}

 


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

-Advertisement-
Play Games
更多相關文章
  • 你愛好的運動是什麼?全選/全不選 足球 籃球 羽毛球 乒乓球 ...
  • 定時器 參數1:函數 參數2:時間 毫秒 1000毫秒--1秒 執行過程: 頁面載入完畢後, 過了1秒, 執行一次函數的代碼, 又過了1秒再執行函數..... 返回值就是定時器的id值 var timeId = setInterval(function () { alert("hello"); }, ...
  • 第二章 需提前瞭解的術語和概念 1. 務必瞭解的CSS世界的專業術語如 1. 屬性: 如上 height , color 2. 值 1. 整數值:z index:1 中的1,屬於,也是 2. 數值: line height:1.5 中的1.5,屬於 3. 百分比值:padding:50%中的50%。 ...
  • 基本使用 寫在Script 標簽里 引入外部js文件:\ console.log(" ") 方法用於在控制台輸出信息 註意事項 嚴格區大小寫 每一行完整語句後面加分號 變數名不能使用關鍵字和保留字 代碼要縮進,保持可讀性 修改元素內容 獲取元素 通過id獲取元素:document.getElemen ...
  • 原生JS DOM的內置屬性 outerHTML 可用來獲取當前節點的html代碼(包含當前節點),且此屬性可使用jQuery的prop()獲取 <div id="demo-test-01"><p>Hello World !!!</p></div> <script> $(function () { l ...
  • 一.插槽是個什麼玩意,能吃嗎 在vue中【插槽】,從字面意思來看,插槽意味著【內容的增加】,回到vue的使用場景,插槽就是【父組件調用子組件時,額外增加的內容】。 插槽顯不顯示、顯示的內容是由父組件來控制的,而插槽在哪裡顯示由子組件來決定 二.插槽怎麼用,好用嗎 1.預設插槽 父組件 1 <temp ...
  • BOM JavaScript分三個部分: 1. ECMAScript標準 基本語法 2. DOM >Document Object Model 文檔對象模型,操作頁面元素的 3. BOM >Browser Object Model 瀏覽器對象模型, 操作瀏覽器的 瀏覽器中有個 頂級對象 :windo ...
  • 一.介紹 當你要在手機軟鍵盤中觸發一些方法,就可以使用input標簽的bindconfirm事件.這個事件的作用是當你在軟鍵盤上點擊確認的時候,將觸發你指定的方法. 還可以使用confirm-type指定軟鍵盤上確認按鈕的名稱.比如你用這個來做搜索框,那麼你就可以指定為confirm-type=“s ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...