整合营销服务商

电脑端+手机端+微信端=数据同步管理

免费咨询热线:

在 CSS 中隐藏元素的 10 种方法

CSS中很多隐藏元素的方法,但这些方法的可访问性、布局、动画、性能和事件处理的方式有所不同。

  • 动画: 一些CSS隐藏元素的方法一般是全有或者全无,元素要么是完全可见,要么是完全不可见,并且没有中间状态。其他的,比如透明度,可以是一个范围的值,所以在这中间过程插入动画成为可能;
  • 可访问性: 下面的每一种方法都会在视觉上隐藏一个元素,但不一样会真正的去除DOM元素。有一些方式隐藏元素后,屏幕阅读器仍然能读取到元素内容;
  • 事件处理: 隐藏元素之后,有些方式元素上的事件仍然能被触发,而有些方式就会导致元素上的事件触发无效;
  • 表现: 浏览器加载并解析 HTML DOM 和 CSS 对象模型后,页面将分三个阶段呈现:布局(生成每个元素的几何位置)、绘制(绘制每个元素的像素)、组合(以适当的顺序放置元素层)。仅导致构图变化的效果明显比影响布局的效果更好。在某些情况下,浏览器还可以使用硬件加速。

下面就来看看CSS中隐藏元素的方式,以及每种方式的优缺点。

1. opacity 和 filter: opacity()

opacity: N 和 filter: opacity(N) 属性可以传递一个 0 到 1 之间的数字,或者 0% 和 100% 之间的百分比,对应地表示完全透明和完全不透明。

  • opacity: N:该属性用来设置元素的透明度;
  • filter: opacity(N) :filter属性用来设置元素的滤镜,opacity是滤镜重的透明度,用来设置元素的透明度。
div {
    opacity: 0;
}

div {
    filter: opacity(0%);
}
复制代码

在现代浏览器中,这两者之间几乎没有实际的区别,但如果同时应用多种效果(模糊、对比度、灰度等)时,应该使用 filter 属性。

注意:opacity 可以设置动画并提供出色的性能,但页面上保留完全透明的元素可能会触发事件。



2. color alpha 透明度

可以将元素的color、background-color 和 border-color 等属性设置为rgba(0,0,0,0),这样就会使元素完全透明:

div {
	color: rgba(0,0,0,0);
  background-color: rgba(0,0,0,0);
}
复制代码

这三个属性都是支持设置动画效果的,需要注意,透明度不能应用于带有背景图片的元素,除非它们是使用 linear-gradient 或类似方法生成的。

Alpha 通道可以设置为:

  • transparent:完全透明(中间不能插入动画);
  • rgba(r, g, b, a):红色、绿色、蓝色和 alpha;
  • hsla(h, s, l, a):色相、饱和度、亮度和 alpha;
  • #RRGGBBAA 或 #RGBA。

3. transform

transform 属性可以用于元素的平移、缩放、旋转或倾斜等。可以使用 scale(0) 或者 translate(-9999px, 0px) 属性值来将元素隐藏:

div {
	transform: scale(0);
}

div {
	translate(-9999px, 0px)
}
复制代码

transform 属性提供了出色的性能和硬件加速,因为元素被有效地移动到了单独的层中,并且可以在 2D 或 3D 中进行动画处理。原始的布局空间会保持原样,并不会受影响。使用这种方式隐藏的元素不会触发任何事件。



4. clip-path

clip-path 属性可以创建一个剪辑区域,用于确定元素的哪些部分是可见的。使用 clip-path: circle(0) 可以将元素进行隐藏。

div {
	clip-path: circle(0);
}
复制代码

clip-path为添加动画效果提供了空间,不过它只能在现代浏览器中使用。



5. visibility: hidden

visibility 属性可以设置为 visible 或 hidden 来显示和隐藏元素。

div {
	visibility: hidden;
}
复制代码

除非使用collapse值,否则元素使用的空间保持不变。


6. display: none

display 可能是最常用的元素隐藏方法; 。当其值为 none 时元素就隐藏了。被隐藏的元素不会在页面中占据位置,也不会响应绑定的监听事件。

div {
  display: none;
}
复制代码

然而,在大多数情况下,display 可能是最糟糕的 CSS 属性。除非使用 position:absolute 将元素移出文档流,或者采用contain属性,否则它的隐藏过程无法设置动画,并将触发页面重新布局。



7. z-index

可以通过将元素的 z-index 属性设置为负值,以实现元素的隐藏。这实际上就是将元素放在了我们看不到的层。

div {
  z-index: -1;
}
复制代码


8. position

position属性允许使用top、bottom、left、right 从页面中的默认位置移动元素。因此,绝对定位的元素可以通过左键:-9999px 等值移出屏幕:

div {
  position: absolute;
  left: -999px;
}
复制代码



9. 覆盖另一个元素

通过在元素的上面放置与背景颜色相同的元素,可以在视觉上隐藏一个元素。下面来使用::after伪元素来实现:

div::after {
  position: absolute;
  content: '';
  top: 0;
  bottom: 100%;
  left: 0;
  right: 0;
  background-color: #fff;
}
复制代码

虽然这从技术上讲是可以实现的,但是这样做需要更多的代码。



10. 缩小尺寸

可以通过使用width、height、padding、border-width 或 font-size 来缩小元素的尺寸以实现元素的隐藏。可能还需要应用 overflow: hidden; 来确保内容不会溢出。

div {
  height: 0;
  padding: 0;
  overflow: hidden;
}
复制代码

使用这种形式我们可以在隐藏过程中使用动画效果,并且他的性能会比 transform 好很多。


分类:

信每天都在玩,可你知道么?除了那些每天都在用的功能外,我们的微信其实还隐藏着很多不为人知的小秘密。这些秘密或实用或炫酷,但总能给我们带来一些不一样的感受。接下来小编就给大家列举几个,喜欢哪一个就自己试试看吧。

软件名称:微信
软件版本:6.2.0.52
软件大小:29.68MB
软件授权:免费
适用平台:Android
下载地址:http://dl.pconline.com.cn/download/359554.html

微信神秘隐藏代码——//switchtabpos:最富Android味的改造

Android与IOS最不一样的地方,莫过于一个标签栏在下一个标签栏在上了。实话说,Android版微信的界面设计并不出彩,而且相当没有Android味!“//switchtabpos”这段代码的最大用处,就是将Tab栏由之前的下方挪至上方,于是原本还透着浓浓IOS味的UI瞬间就有了Android范。最关键的是,这还是一条开关码,什么时候用腻了,再输入一遍,立马就能还原回之前的样子。

图01 还原Android微信的本来味!

微信神秘隐藏代码——//multiwebview:聊天看文章互不打扰

很多网友都遇到过这种情况,看文章时碰巧来条信息,回复完毕再退回原来位置时,发现文章已经消失,只能重新再开一遍。其实导致这类问题的主要原因,是微信将聊天与看文章共用一条任务,一条打开另一条自然被挤掉。“//multiwebview”的含义是将聊天页与文章页独立显示,代码执行后,聊天页和文章页会自动分成两组任务,一个页面操作时,再也不会影响到另一个页面操作了。唯一一个麻烦,就是这段代码对系统的要求有点高,必须得Android 5.0才有效果。

图02 让微信聊天与读文章互不干扰

微信神秘隐藏代码——//sightinfo:实时显示视频参数

小视频大家都玩过,或许你想了解一下这些视频的相关参数。“//sightinfo”这条代码能让视频发布时,自动显示帧率、大小、时长、分辨率等内容,让视频信息一目了然。和“//switchtabpos”一样,“//sightinfo”也是一条开关码,什么时候不需要了,再从输入框中输一遍就行,重启微信生效。

图03 实时显示视频信息

微信神秘隐藏代码——//getfpkey:极客版“关于手机”

这是一条能将手机信息显示出来的代码,类似于“关于手机”,可以提供手机厂商、型号、ROM版本等等内容。不过正如你所看到的,里面的信息非常具有极客范,而且实话说也没啥有营养的东东。所以嘛,大家玩玩也就行了,基本上用处不大。

图04 极客版“关于手机”

微信神秘隐藏代码——//fullexit:退出微信

“//fullexit”是一条手工退出微信的代码,有点像Win7里的shutdown –s,不过要比“设置”面板里的“退出”更彻底。输入代码后,微信随即退出,再次进入时,会提示输入登录密码,接下来嘛相信你都明白了!

图05 很彻底地退出微信

微信神秘隐藏代码——//whatsnew:哄LP绝招?

这条代码很容易让人联想到what‘s new(显示新功能),但事实上不是。输入代码后,微信随即被锁定,屏幕会显示出一个大大的二维码。这里可以有两种方法关闭这一锁屏,一是直接点击最下方的按钮自己解锁,另一种则是让其他好友扫码解锁。不过……锁不是白解的,每次扫完后,对方都会随机向你的钱包打上几块零钱,所以嘛……这东西估计女性朋友们更有用处吧!

图06 这项功能女同胞们估计会喜欢

微信神秘隐藏代码——faxinxi.la:中午吃啥投票吧!

原则说这并不是一条代码,但它所实现的功能却是很多人都想得到的,这就是——“投票“!faxinxi.la的使用非常简单,输入代码后,在弹出页中选择“发起投票”,即可根据屏幕提示设置一组投票。投票支持单选、多选,使用者或发起人还能随时查看投票结果,应该说对付中午吃饭这类普通问题还是相当有实效的。而且正如你所看到的,这条代码的功能并不只限于投票,比方说组织个活动呀、发表个文章、发送个福利神马的,统统可以用它搞定,厉害吧!

图07 中午吃啥,投个票吧!

写在最后

怎么样?大开眼界吧。其实类似的内容在微信中还是很多的,或许我们可以把它看作是一些微信中未解锁的功能。虽然大多数代码目前看都没有很好的界面,而且操作也比较麻烦,但终究可以给我们带来一些不一样的感受。总之还是那句话,如果你对目前每天刷朋友圈这样的生活感觉厌倦的话,那就不妨试试上面这些代码吧。

avaScript奇技淫巧:隐形字符

本文,分享一种奇特的JS编程技巧,功能是:可以使字符串“隐形”、不可见!

效果展示

如下图所示,一个字符串经物别的操作之后,其长度有621字节,但内容却是“隐形”不可见的!

功能用途

这个技术可以应用到很多领域,非常具有实用性。

比如:代码加密、数据加密、文字隐藏、内容保密、隐形水印,等等。

原理介绍

实现字符串隐形,技术原理是“零宽字符”。

什么是“零宽字符”呢?

在Unicode编码中,有一类奇怪的字符格式,它们不可见、不可打印,主要用于调整字符的显示格式。

常见零宽字符类型:

空格符:格式为U+200B,用于较长字符的换行分隔;

非断空格符:格式为U+FEFF,用于阻止特定位置的换行分隔;

连字符:格式为U+200D,用于阿拉伯文与印度语系等文字中,使不会发生连字的字符间产生连字效果;

断字符:格式为U+200C,用于阿拉伯文、德文、印度语系等文字中,阻止会发生连字的字符间的连字效果;

左至右符:格式为U+200E,用于在混合文字方向的多种语言文本中,规定排版文字书写方向为左至右;

右至左符:格式为U+200F : 用于在混合文字方向的多种语言文本中,规定排版文字书写方向为右至左;

在编程实现隐形字符功能时,先将字符串转为二进制,再将二进制中的1转换为\u200b;0转换为\u200c;空格转换为\u200d,最后使用\ufeff 零宽度非断空格符作分隔符。这几种unicode字符都是不可见的,因此最终转化完成并组合后,就会形成一个全不可见的“隐形”字符串。

功能源码

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是专业且强大的JS代码混淆加密工具";
var binary_text = text_2_binary(text);
var hidden_text = binary_2_hidden_text(binary_text);
console.log("原始字符串:",text);
console.log("二进制:",binary_text);
console.log("隐藏字符:",hidden_text,"隐藏字符长度:",hidden_text.length);

隐型还原

接下来介绍“隐形”后的内容如何还原。

在了解上文内容之后,知道了字符隐形的原理,再结合源代码可知:还原隐形内容,即进行逆操作:将隐形的unicode编码转化成二进制,再将二进制转成原本字符。

直接给出源码:

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("隐形字符转二进制:",hidden_text_2_binary(hidden_text));
console.log("二进制转原始字符:",binary_2_Text(hidden_text_2_binary(hidden_text)));

运行效果:

如果在代码中直接提供“隐形”字符内容,比如ajax通信时,将“隐形”字符由后端传给前端,并用以上解密方法还原,那么这种方式传递的内容会是非常隐秘的。

但还是存在一个安全问题:他人查看JS源码,能看到解密函数,这可能引起加密方法泄露、被人推导出加密、解密方法。

对此问题,可以采用JS代码混淆加密,进一步提升整体JS代码安全性。

JS代码加密

JShaman对上面两个解密函数进行代码混淆加密。

如下图,来到JShaman网站,贴入要加密的JS代码:

使用如下配置:

得到加密的JS代码:

将代码粘贴回源文件中:

加密的JS代码,运行起来跟之前完全一样。

但此时,已不再是裸露的透明JS代码,从这混乱复杂的代码中很难看出功能逻辑。

注:“隐形字符”技术,可用于前后端JS执行环境,即可在Node.JS中执行,也可在浏览器中使用。