整合營銷服務(wù)商

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

          免費咨詢熱線:

          CSS實戰(zhàn)篇 - 文字隱藏

          .效果圖

          二.相關(guān)代碼

          <!doctype html>
          <html lang="en">
          <head>
           <meta charset="UTF-8">
           <meta name="Generator" content="EditPlus?">
           <meta name="Author" content="">
           <meta name="Keywords" content="">
           <meta name="Description" content="">
           <title>文字隱藏</title>
           <style>
           div.elli{
           border:1px solid;
           overflow:hidden;/*內(nèi)容會被修剪,并且其余內(nèi)容是不可見的*/
           white-space:nowrap;/*強制在一行顯示*/
           text-overflow:ellipsis;/*顯示省略符號來代表被修剪的文本*/
           width:200px;
           height:20px;
           }
           div.clip
           {
           border:1px solid;
           overflow:hidden; /*超出部分隱藏*/
           white-space:nowrap;/*強制在一行顯示*/
           text-overflow:clip;
           width:200px;
           height:20px;
           }
           div.hide
           {
           overflow:hidden;
           border:1px solid;
           width:200px;
           height:50px;
           }
           div.scroll
           {
           overflow:scroll;/*內(nèi)容會被修剪,但是瀏覽器會顯示滾動條以便查看其余的內(nèi)容*/
           border:1px solid;
           width:200px;
           height:50px;
           }
           </style>
          </head>
          <body>
          <h3 style="color: #98bf21">1.多余文字自動裁剪</h3>
          <div class="clip">如果此處的文字較多,將自動裁切裁切裁切裁切</div>
          <br>
          <h3 style="color: #98bf21">2.多余文字省略號代替</h3>
          <div class="elli"><a href="#">如果此處的文字較多,將自動用省略號代替!</a></div>
          <br>
          <h3 style="color: #98bf21">3.多余文字自動隱藏</h3>
          <div class="hide">如果此處的文字較多,將自動隱藏!如果此處的文字較多,將自動隱藏!如果此處的文字較多,將自動隱藏!如果此處的文字較多,將自動隱藏!如果此處的文字較多,將自動隱藏!</div>
          <br>
          <h3 style="color: #98bf21">4.多余文字出現(xiàn)滾動條</h3>
          <div class="scroll">如果此處的文字較多,將出現(xiàn)滾動條!如果此處的文字較多,將出現(xiàn)滾動條!如果此處的文字較多,將出現(xiàn)滾動條!</div>
          </body>
          </html>
          
          

          三.名詞釋義

          3.1 overflow

          3.2 white-space

          3.3 text-overflow

          CSS 隱藏頁面元素有許多種方法。你可以將 opacity 設(shè)為 0、將 visibility 設(shè)為 hidden、將 display 設(shè)為 none 或者將 position 設(shè)為 absolute 然后將位置設(shè)到不可見區(qū)域。

          你有沒有想過,為什么我們要有這么多技術(shù)來隱藏元素,而它們看起來都實現(xiàn)的是同樣的效果?每一種方法實際上與其他方法之間都有一些細(xì)微的不同,這些 不同決定了在一個特定的場合下使用哪一個方法。這篇教程將覆蓋到那些你需要記住的細(xì)小不同點,讓你根據(jù)不同情況選擇上面這些方法中適合的方法來隱藏元素。

          opacity

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

          .hide {
           opacity: 0;}

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

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

          看下面的例子:

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

          當(dāng)你的鼠標(biāo)移到被隱藏的第 2 個的區(qū)塊上,元素狀態(tài)平滑地從完全透明過渡到完全不透明。區(qū)塊也將 cursor 屬性設(shè)置為了 pointer,這說明了用戶可以與它交互。

          我自己是一名從事了多年開發(fā)的web前端老程序員,目前辭職在做自己的web前端私人定制課程,今年年初我花了一個月整理了一份最適合2019年學(xué)習(xí)的web前端學(xué)習(xí)干貨,各種框架都有整理,送給每一位前端小伙伴,想要獲取的可以關(guān)注我的頭條號并在后臺私信我:前端,即可免費獲取。

          visibility

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

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

          .hide {
           visibility: hidden;}

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

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

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

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

          display

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

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

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

          .hide {
           display: none;}

          看下面的例子:

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

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

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

          position

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

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

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

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

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

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

          clip-path

          隱藏元素的另一種方法是通過剪裁它們來實現(xiàn)。在以前,這可以通過 clip 屬性來實現(xiàn),但是這個屬性被廢棄了,換成一個更好的屬性叫做 clip-path。Nitish Kumar 最近在 SitePoint 發(fā)表了“介紹 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 屬性隱藏元素”

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

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

          結(jié)論

          在這篇教程里,我們看了 5 種不同的通過 CSS 隱藏元素的方法。每一種方法都與其他幾種有一點區(qū)別。知道你想要實現(xiàn)什么有助于你決定采用哪一個屬性,隨著時間推移,你就能根據(jù)實際需求本能地選擇最佳方式了。

          avaScript奇技淫巧:隱形字符

          本文,分享一種奇特的JS編程技巧,功能是:可以使字符串“隱形”、不可見!

          效果展示

          如下圖所示,一個字符串經(jīng)物別的操作之后,其長度有621字節(jié),但內(nèi)容卻是“隱形”不可見的!

          功能用途

          這個技術(shù)可以應(yīng)用到很多領(lǐng)域,非常具有實用性。

          比如:代碼加密、數(shù)據(jù)加密、文字隱藏、內(nèi)容保密、隱形水印,等等。

          原理介紹

          實現(xiàn)字符串隱形,技術(shù)原理是“零寬字符”。

          什么是“零寬字符”呢?

          在Unicode編碼中,有一類奇怪的字符格式,它們不可見、不可打印,主要用于調(diào)整字符的顯示格式。

          常見零寬字符類型:

          空格符:格式為U+200B,用于較長字符的換行分隔;

          非斷空格符:格式為U+FEFF,用于阻止特定位置的換行分隔;

          連字符:格式為U+200D,用于阿拉伯文與印度語系等文字中,使不會發(fā)生連字的字符間產(chǎn)生連字效果;

          斷字符:格式為U+200C,用于阿拉伯文、德文、印度語系等文字中,阻止會發(fā)生連字的字符間的連字效果;

          左至右符:格式為U+200E,用于在混合文字方向的多種語言文本中,規(guī)定排版文字書寫方向為左至右;

          右至左符:格式為U+200F : 用于在混合文字方向的多種語言文本中,規(guī)定排版文字書寫方向為右至左;

          在編程實現(xiàn)隱形字符功能時,先將字符串轉(zhuǎn)為二進(jìn)制,再將二進(jìn)制中的1轉(zhuǎn)換為\u200b;0轉(zhuǎn)換為\u200c;空格轉(zhuǎn)換為\u200d,最后使用\ufeff 零寬度非斷空格符作分隔符。這幾種unicode字符都是不可見的,因此最終轉(zhuǎn)化完成并組合后,就會形成一個全不可見的“隱形”字符串。

          功能源碼

          function text_2_binary(text){
              return text.split('').map(function(char){ return char.charCodeAt(0).toString(2)}).join(' ');
          }
          function binary_2_hidden_text(binary){
              return binary.split('').map(function (binary_num){
                  var num = parseInt(binary_num, 10);
                  if (num === 1) {
                      return '\u200b';
                  } else if(num===0) {
                      return '\u200c';
                  }
                  return '\u200d';
              }).join('\ufeff')
          }
          var text = "jshaman是專業(yè)且強大的JS代碼混淆加密工具";
          var binary_text = text_2_binary(text);
          var hidden_text = binary_2_hidden_text(binary_text);
          console.log("原始字符串:",text);
          console.log("二進(jìn)制:",binary_text);
          console.log("隱藏字符:",hidden_text,"隱藏字符長度:",hidden_text.length);

          隱型還原

          接下來介紹“隱形”后的內(nèi)容如何還原。

          在了解上文內(nèi)容之后,知道了字符隱形的原理,再結(jié)合源代碼可知:還原隱形內(nèi)容,即進(jìn)行逆操作:將隱形的unicode編碼轉(zhuǎn)化成二進(jìn)制,再將二進(jìn)制轉(zhuǎn)成原本字符。

          直接給出源碼:

          function hidden_text_2_binary(string){
            return string.split('\ufeff').map(function(char){
              if (char === '\u200b') {
                return '1';
              } else if(char === '\u200c') {
                return '0';
              }
              return ' ';
            }).join('')
          }
          function binary_2_Text(binaryStr){
            var text = ""
            binaryStr.split(' ').map(function(num){
              text += String.fromCharCode(parseInt(num, 2));
            }).join('');
            return text.toString();
          }
          console.log("隱形字符轉(zhuǎn)二進(jìn)制:",hidden_text_2_binary(hidden_text));
          console.log("二進(jìn)制轉(zhuǎn)原始字符:",binary_2_Text(hidden_text_2_binary(hidden_text)));

          運行效果:

          如果在代碼中直接提供“隱形”字符內(nèi)容,比如ajax通信時,將“隱形”字符由后端傳給前端,并用以上解密方法還原,那么這種方式傳遞的內(nèi)容會是非常隱秘的。

          但還是存在一個安全問題:他人查看JS源碼,能看到解密函數(shù),這可能引起加密方法泄露、被人推導(dǎo)出加密、解密方法。

          對此問題,可以采用JS代碼混淆加密,進(jìn)一步提升整體JS代碼安全性。

          JS代碼加密

          JShaman對上面兩個解密函數(shù)進(jìn)行代碼混淆加密。

          如下圖,來到JShaman網(wǎng)站,貼入要加密的JS代碼:

          使用如下配置:

          得到加密的JS代碼:

          將代碼粘貼回源文件中:

          加密的JS代碼,運行起來跟之前完全一樣。

          但此時,已不再是裸露的透明JS代碼,從這混亂復(fù)雜的代碼中很難看出功能邏輯。

          注:“隱形字符”技術(shù),可用于前后端JS執(zhí)行環(huán)境,即可在Node.JS中執(zhí)行,也可在瀏覽器中使用。


          主站蜘蛛池模板: 波多野结衣AV无码久久一区| 日韩精品无码免费一区二区三区| 一本AV高清一区二区三区| 亚洲国产成人一区二区精品区 | 国产亚洲综合精品一区二区三区 | 日韩精品一区二区三区中文| 国产怡春院无码一区二区| 亚洲国产精品乱码一区二区| 久久精品一区二区三区中文字幕| 在线|一区二区三区| 色欲AV蜜桃一区二区三| 国产精品无码一区二区三区不卡| 亚洲高清一区二区三区电影| 亚洲AV香蕉一区区二区三区| 无码人妻精品一区二区蜜桃 | 亚洲综合无码一区二区痴汉 | 91在线看片一区国产| 国产福利一区二区三区视频在线| 天堂va在线高清一区| 在线一区二区三区| 色妞AV永久一区二区国产AV| 国产情侣一区二区三区| 色欲AV蜜臀一区二区三区| 中文乱码人妻系列一区二区 | 一区在线免费观看| 国产在线精品一区二区不卡麻豆| 熟妇人妻系列av无码一区二区 | 国产探花在线精品一区二区| 久久国产一区二区三区| 亚洲国产欧美日韩精品一区二区三区 | 亚洲Av永久无码精品一区二区| 精品一区二区三区无码免费视频| 农村人乱弄一区二区 | 日本激情一区二区三区| 欧美日韩国产免费一区二区三区 | 亚洲AV永久无码精品一区二区国产| 乱色熟女综合一区二区三区| 国产在线精品一区二区不卡| 亚洲视频一区网站| 亚洲Aⅴ无码一区二区二三区软件| 久久精品国产一区二区三区不卡|