整合營銷服務商

          電腦端+手機端+微信端=數據同步管理

          免費咨詢熱線:

          Web前端工程師應該知道的用 CSS 隱藏頁面元素的方法!

          有沒有想過,為什么我們要有這么多技術來隱藏元素,而它們看起來都實現的是同樣的效果?每一種方法實際上與其他方法之間都有一些細微的不同,這些不同決定了在一個特定的場合下使用哪一個方法。今天就帶大家了解一下不同的方法分別用于那種場合更合適,下面就讓我們一起來看一看吧!

          一、opacity

          opacity 屬性的意思是設置一個元素的透明度。它不是為改變元素的邊界框(bounding box)而設計的。這意味著將 opacity 設為 0 只能從視覺上隱藏元素。而元素本身依然占據它自己的位置并對網頁的布局起作用。它也將響應用戶交互。

          .hide {
          opacity: 0;}
          

          如果你打算使用 opacity 屬性在讀屏軟件中隱藏元素,很不幸,你并不能如愿。元素和它所有的內容會被讀屏軟件閱讀,就像網頁上的其他元素那樣。換句話說,元素的行為就和它們不透明時一致。

          我還要提醒一句,opacity 屬性可以用來實現一些效果很棒的動畫。任何 opacity 屬性值小于 1 的元素也會創建一個新的堆疊上下文(stacking context)。

          看下面的例子:

          看 @SitePoint 提供的例子“用 opacity 隱藏元素”

          當你的鼠標移到被隱藏的第 2 個的區塊上,元素狀態平滑地從完全透明過渡到完全不透明。區塊也將 cursor 屬性設置為了 pointer,這說明了用戶可以與它交互。

          二、visibility

          第二個要說的屬性是 visibility。將它的值設為 hidden 將隱藏我們的元素。如同 opacity 屬性,被隱藏的元素依然會對我們的網頁布局起作用。與 opacity 唯一不同的是它不會響應任何用戶交互。此外,元素在讀屏軟件中也會被隱藏。

          這個屬性也能夠實現動畫效果,只要它的初始和結束狀態不一樣。這確保了 visibility 狀態切換之間的過渡動畫可以是時間平滑的(事實上可以用這一點來用 hidden 實現元素的延遲顯示和隱藏——譯者注)。

          .hide {
          visibility: hidden;}
          

          下面的例子演示了 visibility 與 opacity 有怎樣的不同:

          看 @SitePoint 提供的例子“用 visibility 隱藏元素”

          注意,如果一個元素的 visibility 被設置為 hidden,同時想要顯示它的某個子孫元素,只要將那個元素的 visibility 顯式設置為 visible 即可(就如例子里面的 .o-hide p——譯者注)。嘗試只 hover 在隱藏元素上,不要 hover 在 p 標簽里的數字上,你會發現你的鼠標光標沒有變成手指頭的樣子。此時,你點擊鼠標,你的 click 事件也不會被觸發。

          而在 <div> 標簽里面的 <p> 標簽則依然可以捕獲所有的鼠標事件。一旦你的鼠標移動到文字上,<div> 本身變得可見并且事件注冊也隨之生效。

          三、display

          display 屬性依照詞義真正隱藏元素。將 display 屬性設為 none 確保元素不可見并且連盒模型也不生成。使用這個屬性,被隱藏的元素不占據任何空間。不僅如此,一旦 display 設為 none 任何對該元素直接打用戶交互操作都不可能生效。此外,讀屏軟件也不會讀到元素的內容。這種方式產生的效果就像元素完全不存在。

          任何這個元素的子孫元素也會被同時隱藏。為這個屬性添加過渡動畫是無效的,它的任何不同狀態值之間的切換總是會立即生效。

          不過請注意,通過 DOM 依然可以訪問到這個元素。因此你可以通過 DOM 來操作它,就像操作其他的元素。

          .hide {
          display: none;}
          

          看下面的例子:

          @SitePoint 提供的例子“用 display 隱藏元素”

          你將看到第二個塊元素內有一個 <p> 元素,它自己的 display 屬性被設置成 block,但是它依然不可見。這是 visibility:hidden 和 display:none 的另一個不同之處。在前一個例子里,將任何子孫元素 visibility 顯式設置成 visible 可以讓它變得可見,但是 display 不吃這一套,不管自身的 display值是什么,只要祖先元素的 display 是 one,它們就都不可見。

          現在,將鼠標移到第一個塊元素上面幾次,然后點擊它。這個操作將讓第二個塊元素顯現出來,它其中的數字將是一個大于 0 的數。這是因為,元素即使被這樣設置成對用戶隱藏,還是可以通過 JavaScript 來進行操作。

          四、position

          假設有一個元素你想要與它交互,但是你又不想讓它影響你的網頁布局,沒有合適的屬性可以處理這種情況(opacity 和 visibility 影響布局, display 不影響布局但又無法直接交互——譯者注)。在這種情況下,你只能考慮將元素移出可視區域。這個辦法既不會影響布局,有能讓元素保持可以操作。下面是采用這 種辦法的 CSS:

          .hide {
          position: absolute;
          top: -9999px;
          left: -9999px;}
          

          下面的例子闡明了怎樣通過絕對定位的方式隱藏元素,并讓它和前面的那個例子效果一樣:

          看 @SitePoint 提供的例子“用 position 屬性隱藏元素”

          這種方法的主要原理是通過將元素的 top 和 left 設置成足夠大的負數,使它在屏幕上不可見。采用這個技術的一個好處(或者潛在的缺點)是用它隱藏的元素的內容可以被讀屏軟件讀取。這完全可以理解,是因為你只是將元素移到可視區域外面讓用戶無法看到它。

          你得避免使用這個方法去隱藏任何可以獲得焦點的元素,因為如果那么做,當用戶讓那個元素獲得焦點時,會導致一個不可預料的焦點切換。這個方法在創建 自定義復選框和單選按鈕時經常被使用。(用 DOM 模擬復選框和單選按鈕,但用這個方法隱藏真正的 checkbox 和 radio 元素來“接收”焦點切換——譯者注)

          五、clip-path

          隱藏元素的另一種方法是通過剪裁它們來實現。在以前,這可以通過 clip 屬性來實現,但是這個屬性被廢棄了,換成一個更好的屬性叫做 clip-path。Nitish Kumar 最近在 SitePoint 發表了“介紹 clicp-path 屬性”這篇文章,通過閱讀它可以了解這個屬性的更多高級用法。

          記住,clip-path 屬性還沒有在 IE 或者 Edge 下被完全支持。如果要在你的 clip-path 中使用外部的 SVG 文件,瀏覽器支持度還要更低。使用 clip-path 屬性來隱藏元素的代碼看起來如下:

          .hide {
          clip-path: polygon(0px 0px,0px 0px,0px 0px,0px 0px);}
          

          下面是一個實際使用它的例子:

          看 @SitePoint 提供的例子“用 clip-path 屬性隱藏元素”

          如果你把鼠標懸停在第一個元素上,它依然可以影響第二個元素,盡管第二個元素已經通過 clip-path 隱藏了。如果你點擊它,它會移除用來隱藏的 class,讓我們的元素從那個位置顯現出來。被隱藏元素中的文字仍然能夠通過讀屏軟件讀取,許多 WordPress 站點使用 clip-path 或者之前的 clip來實現專門為讀屏軟件提供的文字。

          雖然我們的元素自身不再顯示,它也依然占據本該占據的矩形大小,它周圍的元素的行為就如同它可見時一樣。記住用戶交互例如鼠標懸停或者點擊在剪裁區 域之外也不可能生效。在我們的例子里,剪裁區大小為零,這意味著用戶將不能與隱藏的元素直接交互。此外,這個屬性能夠使用各種過渡動畫來實現不同的效果。

          這五種CSS隱藏元素方法每一種用到的情況都不同,需要大家根據實際情況去判斷,隨著練習實戰的增多,相信大家對CSS隱藏元素就能做到得心應手了。也可以加入465042726,一起討論關于web前端方面的問題。

          們之前曾辯稱,在線匿名非常重要。隨著隱私概念逐年被踐踏,在線隱私變得更加重要。你會驚訝于有人可以用你的IP地址做些什么。

          這就是為什么許多人使用假IP地址。要明確的是,假IP地址有點用詞不當意味著憑空創造一個新的地址。那是不可能的。您可以做的最好的事情是將您的IP地址隱藏在其他人已經存在的IP地址之后。

          這意味著您無法在互聯網上真正匿名 - 您的行為可以追溯到您。但屏蔽您的IP地址足以實現功能匿名。

          方法1:使用VPN

          VPN代表虛擬專用網絡,但比聽起來要簡單得多。基本上,您可以將計算機或設備連接到其他人的網絡,然后通過網絡瀏覽網頁。無論你做什么活動看起來都來自他們,而不是來自

          當您連接到VPN時,您將使用該網絡上的某個IP地址屏蔽您的IP地址。要追溯到您的流量,VPN將不得不放棄(或者您的IP地址必須通過DNS泄漏泄露)。

          為獲得最佳效果,請使用付費VPN服務,因為免費VPN帶來了太多風險和不利因素。在眾多風險中,最重要的是您永遠不會完全信任免費服務。

          淘寶上就有很多此類的商家。收費VPN不會保留活動日志,安全性也是大大的提升。此外,大多數無記錄VPN可以加密進出網絡的所有流量,防止黑客進行任何窺探。

          所以說VPN在很多情況下都很有用。

          方法2:使用Web代理

          一個Web代理工作在大致相同的方式作為一個VPN:您連接到代理服務器,那么你所有的網絡流量流經代理服務器。因此,您的IP地址被代理服務器的IP地址隱藏。

          但代理和VPN之間存在兩個主要差異。

          首先,網絡代理通常是未加密的。即使您的IP地址被代理掩蓋,流量本身仍然可以被ISP和政府嗅探。不僅如此,一些網站仍然可以使用Flash或JavaScript 查看您的真實IP地址。

          其次,某些瀏覽器允許您僅由瀏覽器流量。要使用Web代理,您可以進入Web瀏覽器的設置并手動輸入代理服務器的IP地址。這允許Web瀏覽器之外的應用程序和設備(如Skype)仍然使用您的實際IP地址。

          如何在Firefox中設置Web代理

          1. 在主菜單中,選擇選項
          2. 導航到高級選項卡,然后“網絡”部分。
          3. 在連接下,單擊設置...
          4. 選擇手動代理配置,然后在HTTP代理字段中鍵入代理的地址和端口。

          如何在Microsoft Edge中設置Web代理

          1. 在主菜單中,選擇設置
          2. 向下滾動并單擊查看高級設置
          3. 向下滾動并單擊打開代理設置
          4. 在手動代理設置下,啟用使用代理服務器,然后在地址字段中輸入代理的地址和端口。

          如何在Chrome,Opera,Vivaldi中設置Web代理

          1. 在主菜單中,選擇設置
          2. 在網絡下,單擊更改代理設置...
          3. 在“連接”選項卡中,單擊 LAN設置
          4. 啟用為LAN使用代理服務器,然后在地址字段中鍵入代理的地址和端口。

          注意: Chrome,Opera,Vivaldi和其他基于Chromium的瀏覽器沒有內置的瀏覽器特定代理功能。相反,他們只使用系統范圍的代理設置。但是,您可以使用Proxy Switcher和Manager之類的擴展來使用僅影響瀏覽器流量的Web代理。

          方法3:使用公共Wi-Fi

          您可以選擇直接連接到他們的網絡,最簡單的方法是跳轉到 公共Wi-Fi

          有趣的是,這是隱藏家庭IP地址的唯一方法。當您使用公共Wi-Fi時,別人無法將其追溯到您的家中。如果它是一個受歡迎的熱點(例如星巴克),您的活動將會被其他幾十個用戶隨時遮擋。但請記住,公共Wi-Fi有其自身的風險!

          1. /隱藏不留痕跡
          2. <input type="hidden" />

          主站蜘蛛池模板: 国产91一区二区在线播放不卡| 日韩A无码AV一区二区三区| 亚洲一区二区三区在线网站| 美女毛片一区二区三区四区| 日本在线观看一区二区三区| 无码av人妻一区二区三区四区| 国产一区二区三区精品视频 | 八戒久久精品一区二区三区 | 国产综合精品一区二区| 老熟女五十路乱子交尾中出一区| 一区二区三区免费视频网站| 国精产品999一区二区三区有限| 国产成人无码一区二区在线播放 | 国内精品一区二区三区最新 | 免费看AV毛片一区二区三区| 五月婷婷一区二区| 人妻激情偷乱视频一区二区三区| 无码少妇一区二区浪潮av| 亚洲福利秒拍一区二区| 亚洲一区二区三区在线观看精品中文 | 国产香蕉一区二区在线网站| 国产av一区二区三区日韩| 亚洲日韩国产欧美一区二区三区 | 综合激情区视频一区视频二区| 无码喷水一区二区浪潮AV| 亚洲国产AV一区二区三区四区| 国产日本亚洲一区二区三区| 91在线一区二区三区| 亚洲国产精品综合一区在线| 精品视频一区二区三三区四区| 麻豆天美国产一区在线播放| 久久国产精品无码一区二区三区| 国产成人精品无码一区二区| 国产人妖视频一区二区| 亚洲AV无码一区东京热| 国产福利91精品一区二区| 国产精品一区二区毛卡片| 日韩视频一区二区| 久久精品综合一区二区三区| 精品aⅴ一区二区三区| 人妻体内射精一区二区三区|