整合營銷服務商

          電腦端+手機端+微信端=數(shù)據(jù)同步管理

          免費咨詢熱線:

          各種getElementBy**的區(qū)別和總結,附示例代碼一看就懂

          生js里的DOM操作,首先要獲取待操作的元素,而初學者對獲取元素所使用的getElement的幾個方法是不是經(jīng)常容易混呢?看了本文就全明白了!

          一般說明:

          1、注意大小寫!

          2、注意其中Element的單、復數(shù)!

          方法一:getElementById

          通過Id來取得元素,Id是唯一的,示例如下:

          <div id="cat"></div>
          <script>
          	a = document.getElementById('cat');
          	a.innerHTML = "hello cat!";
          </script>
          

          說明:在這個代碼中,a為id是cat的元素,操作a把它的內(nèi)容改成 hello cat!

          getElementById 這個方法是最常用的,通常記住這個就夠你用的了!

          方法二:getElementsByName

          通過NAME來獲得元素,

          注意,因為NAME可以重復,所以Element是復數(shù),要加個s,所以這個方法是取得一個數(shù)組。IE不支持。示例如下:

          <div name="dog">第一個</div>
          <div name="dog">第二個</div>
          <script>
          	a = document.getElementsByName('dog');
          	a[1].innerHTML = "hello dog!";
          </script>
          

          說明:在這個代碼中,a為所有name是dog的元素集合,操作其中的第2個,把內(nèi)容改成 hello dog!

          方法三:getElementsByTagName

          通過TAGNAME(HTML的標簽名字)來獲得元素,

          注意,因為標簽可以重復,所以Element是復數(shù),要加個s,所以這個方法也是取得一個數(shù)組。示例如下:

          <div>
          	<span>第一個</span>
          	<span>第二個</span>
          </div>
          <script>
          	a = document.getElementsByTagName('span');
          	a[1].innerHTML = "hello span!";
          </script>
          

          說明:在這個代碼中,a為所有標簽是span的元素集合,操作其中的第2個,把內(nèi)容改成 hello span!

          方法四:getElementsByClassName

          通過class(樣式名)來獲得元素,

          注意,因為樣式引用可以重復,所以Element是復數(shù),要加個s,所以這個方法也是取得一個數(shù)組。示例如下:

          <div class="apple">第一個</div>
          <div class="apple">第二個</div>
          <script>
          	a = document.getElementsByClassName('apple');
          	a[1].innerHTML = "hello apple!";
          </script>
          

          說明:在這個代碼中,a為所有樣式class是apple的元素集合,操作其中的第2個,把內(nèi)容改成 hello apple!

          至此四個方法都搞定了!再也不會混淆了吧?

          javascript開發(fā)中我們會經(jīng)常獲取頁面中的事件對象,然后來處理這些事件,例如下面的getEvent函數(shù)就是獲取javascript下的頁面事件對象。

          function getEvent(event){
          return event || window.event;
          }

          hrome 126 于近期發(fā)布了穩(wěn)定版本,其中一個比較有意思的更新是給 HTML 帶來一個新的元素:<permission> ,它將從這個版本開始試用,并且正在努力走向標準化。

          今天我們一起來看下這個 <permission> 元素的用法。

          Web 權限提示的問題

          當 Web 應用程序需要訪問瀏覽器的高級功能時,需要向用戶主動請求許可。例如,當百度地圖使用 Geolocation API 獲取用戶的地理位置時,瀏覽器會提示用戶申請權限,這是權限規(guī)范中定義明確的概念。

          申請權限的觸發(fā)方式一般分為兩類,被動隱式觸發(fā),或者主動顯示觸發(fā):

          例如,Geolocation API 是一個強大的 API,它的使用依賴于首次使用時隱式詢問的方法。例如,當程序調(diào)用 navigator.geolocation.getCurrentPosition() 方法時,權限提示框會在第一次調(diào)用時自動彈出,還有另外一個例子是 navigator.mediaDevices.getUserMedia()

          一些其他的 API,如 Notification APIDevice Orientation API,通常有一種顯式的方式通過靜態(tài)方法來請求權限,如 Notification.requestPermission()DeviceMotionEvent.requestPermission()

          網(wǎng)站可以在加載時立即調(diào)用諸如 navigator.mediaDevices.getUserMedia()Notification.requestPermission() 等方法。這會導致在用戶還沒與網(wǎng)站進行交互時就彈出權限提示。這就是明顯的權限濫用行為,并且影響到兩種方式,既包括首次使用時的隱含詢問,也包括提前明確請求。

          權限濫用導致瀏覽器廠商要求有像點擊按鈕或按下按鍵這樣的用戶操作,然后才會顯示權限提示。這種方法的問題在于,瀏覽器很難確定某個特定的用戶操作是否應該導致顯示權限提示。也許用戶只是因為頁面加載時間太長而在頁面上隨意某個地方隨便點擊,有些網(wǎng)站也變得非常擅長誘騙用戶點擊內(nèi)容來觸發(fā)提示。

          另一個問題是權限提示框通常顯示的方式:在網(wǎng)站的 “死亡線” 之上(特別是在大屏幕上),也就是說,在應用程序能夠繪制到的瀏覽器窗口區(qū)域之外。用戶在剛剛點擊了窗口底部的一個按鈕后,可能會錯過瀏覽器窗口頂部的提示,這種情況還是挺常見的。當瀏覽器有應對權限濫用的緩解措施時,這個問題往往會更加嚴重。

          另外,用戶一旦做出了拒絕某個權限的操作,之后想要改變就不太容易了。他們得找到特定的地方,比如那個網(wǎng)站信息下拉菜單,然后去進行重置或調(diào)整權限的操作,而且還得重新加載頁面才行。網(wǎng)站也沒辦法提供很方便的途徑讓用戶快速改變權限狀態(tài),還得詳細地告訴用戶怎么去找到地方改變設置。

          如果某個權限是非常重要的,比如視頻會議軟件要用麥克風權限,那像谷歌會議這類的軟件就會彈出很顯眼的對話框來告訴用戶怎么去把之前阻止的權限給開通。

          <permission>元素

          為了解決上面的這些問題,<permission> 元素誕生了。這個元素允許開發(fā)者以聲明方式請求使用權限,如下例所示:

          <permission type="camera" />

          “type” 屬性代表你正在請求的權限列表(如果有多個可以以空格分割)。目前,允許的值是 'camera''microphone' 以及 'camera microphone'。默認情況下,這個元素呈現(xiàn)出來的樣子類似于具有最簡用戶代理樣式的按鈕。

          對于某些允許附加參數(shù)的權限,type-ext 屬性接受以空格分隔的鍵值對,例如 precise:true 地理位置權限。

          當用戶與 <permission> 元素交互時,他們可以循環(huán)經(jīng)歷各個階段:

          如果他們之前不允許某項功能,他們可以在每次訪問時允許該功能,或者在當前訪問時允許該功能。

          如果他們之前允許該功能,他們可以繼續(xù)允許,或者停止允許。

          如果他們之前不允許某項功能,他們可以繼續(xù)不允許它,或者這次允許它。

          <permission> 元素的文本會根據(jù)狀態(tài)自動更新。例如,如果已授予使用某項功能的權限,則文本會更改為表示允許使用該功能。如果需要先授予權限,則文本會更改為邀請用戶使用該功能。將之前的屏幕截圖與以下屏幕截圖進行比較,以查看這兩種狀態(tài)。

          <permission> 元素可以與 Permissions API 一起使用。有許多事件可供監(jiān)聽:

          • onpromptdismiss:當元素觸發(fā)的權限提示被用戶關閉(例如,單擊關閉按鈕或單擊提示之外)時,會觸發(fā)此事件。
          • onpromptaction:當元素觸發(fā)的權限提示已被用戶對提示本身采取某種操作解決時,觸發(fā)此事件。這并不一定意味著權限狀態(tài)已經(jīng)改變,用戶可能已經(jīng)采取了維持現(xiàn)狀的操作(例如繼續(xù)允許權限)。
          • onvalidationstatuschange:當元素從 "valid" 切換到 "invalid" 時觸發(fā)此事件,例如當元素被其他超文本標記語言內(nèi)容部分遮擋時,會認為是 "invalid"。

          我們可以直接在 HTML 代碼中內(nèi)聯(lián)注冊這些事件的事件監(jiān)聽器(<permission type="…" onpromptdismiss="alert('The prompt was dismissed');" />),或者在 <permission> 元素上使用 addEventListener()

          <permission type="camera" />
          <script>
            const permission = document.querySelector('permission');
            permission.addEventListener('promptdismiss', showCameraWarning);
          
            function showCameraWarning() {
              // Show warning that the app isn't fully usable
              // unless the camera permission is granted.
            }
          
            const permissionStatus = await navigator.permissions.query({name: "camera"});
            permissionStatus.addEventListener('change', () => {
              // Run the check when the status changes.
              if (permissionStatus.state === "granted") {
                useCamera();
              }
              // Run the initial check.
              if (permissionStatus.state === "granted") {
                useCamera();
              }
            });
          </script>

          最后

          參考:https://developer.chrome.com/blog/permission-element-origin-trial


          主站蜘蛛池模板: 精品亚洲一区二区三区在线播放| 国产精品自拍一区| 精品无码人妻一区二区免费蜜桃| 国产精品一区12p| 亚洲天堂一区在线| 国产成人精品一区在线| 日韩好片一区二区在线看| 成人免费一区二区无码视频| 精品国产香蕉伊思人在线在线亚洲一区二区 | 奇米精品一区二区三区在线观看| 日韩一区二区视频| 久久亚洲一区二区| 一区免费在线观看| 国产精品av一区二区三区不卡蜜| 亚洲国产综合精品中文第一区| 国产精品第一区揄拍无码| 中文字幕在线看视频一区二区三区| 合区精品久久久中文字幕一区| 日韩高清一区二区| 亚洲综合一区国产精品| 国产精品视频分类一区| 色狠狠AV一区二区三区| 亚洲AV成人一区二区三区AV| 久久国产精品免费一区二区三区| 最新中文字幕一区二区乱码| 亚洲AV无码一区二区三区人 | 日韩一区二区三区精品| 天堂一区二区三区在线观看| 呦系列视频一区二区三区| 蜜臀AV在线播放一区二区三区| 无码精品一区二区三区在线| 日本高清不卡一区| 视频一区二区在线观看| 亚洲欧美日韩国产精品一区| 中文字幕永久一区二区三区在线观看| 色欲综合一区二区三区| 国产不卡视频一区二区三区| 亚洲无圣光一区二区| 亚洲色欲一区二区三区在线观看| 美女视频一区三区网站在线观看| 亚洲爽爽一区二区三区|