前言

可控密度的虚线分隔线 css


.line {
height: 1px;
width: 100%;
transform: scaleY(0.4);
-webkit-transform: scaleY(0.4);
background-image: linear-gradient(to right, #ccc 0%, #ccc 50%, transparent 50%);
background-size: 4px 1px;
background-repeat: repeat-x;
}
  • 通过更改background-size值控制密度展示
  • 通过各属性x,y及方向转换实现横/纵向不同的分隔线

文字渐隐 css


.article{
position: relative;
} .mask{
position: absolute;
width:100%;
bottom:0;
left: 0;
height: 60px;
background: linear-gradient(top, rgba(255,255,255,0), #fff);
background: -webkit-linear-gradient(top, rgba(255,255,255,0), #fff);
}
    春眠不觉晓<br />
处处闻啼鸟<br />
夜来风雨声<br />
花落知多少
<div class="mask"></div>
</div>
  • 引导用户下方仍有内容,即将接近底部时div.mask隐藏

弹窗禁止/恢复背景层滚动 css+js


window.onload = function(){
document.getElementById('modalBtn').onclick = function (){switchModalStatus(true)};
document.getElementById('modal').onclick = function (){switchModalStatus(false)};
} function switchModalStatus(needShow){
var modal = document.getElementById('modal');
if(needShow){
modal.style.display = 'block';
disableBodyScroll();
}else{
modal.style.display = 'none';
enableBodyScroll();
}
} function disableBodyScroll() {
var body = document.body;
window.stTemp = Math.max(body.scrollTop, document.documentElement.scrollTop);
body.style.overflow = "hidden";
body.style.position = "fixed";
body.style.top = (-window.stTemp+'px');
} function enableBodyScroll() {
var body = document.body;
body.style.overflow = "scroll";
body.style.position = "static";
body.style.top = '0px';
body.scrollTop = window.stTemp;
document.documentElement.scrollTop = window.stTemp;
}

.modal{
position: fixed;
top: 0;
left: 0;
width: 100%;
height: 100%;
background: rgba(0, 0, 0, .5);
z-index: 1;
} .modal > .content{
position: absolute;
top: 50%;
left: 50%;
transform: translateX(-50%) translateY(-50%);
-webkit-transform: translateX(-50%) translateY(-50%);
padding: 10px;
width: 50%;
background: white;
border-radius: 12px;
}
<div id="modal" class="modal" style="display:none">
<div class="content">我是弹窗</div>
</div>

多行文字溢出显示省略号 css


.text {
text-align: left;
display: -webkit-box;
-webkit-line-clamp: 2;
-webkit-box-orient: vertical;
overflow: hidden;
text-overflow: ellipsis;
}

  • -webkit-line-clamp控制显示的行数

原文地址:https://segmentfault.com/a/1190000016879135

前端用户体验优化: JS & CSS 各类效果代码段的更多相关文章

  1. Vue.Js的用户体验优化

    一次基于Vue.Js的用户体验优化   一.写在前面 半年以前,第一次在项目上实践VueJs,由于在那之前,没有Angular,avalon等框架的实践经验,所以在Vue的使用上,没有给自己总结出更多 ...

  2. Google Pagespeed,自动压缩优化JS/CSS/Image

    Google Pagespeed,自动压缩优化JS/CSS/Image 浏览: 发布日期:// 分类:技术分享 关键字: Nginx Appache Pagespeed 自动压缩优化JS/CSS/Im ...

  3. [ionic开源项目教程] - 第10讲 新闻详情页的用户体验优化

    目录 [ionic开源项目教程] 第1讲 前言,技术储备,环境搭建,常用命令 [ionic开源项目教程] 第2讲 新建项目,架构页面,配置app.js和controllers.js [ionic开源项 ...

  4. CDN高级技术专家周哲:深度剖析短视频分发过程中的用户体验优化技术点

    深圳云栖大会已经圆满落幕,在3月29日飞天技术汇-弹性计算.网络和CDN专场中,阿里云CDN高级技术专家周哲为我们带来了<海量短视频极速分发>的主题分享,带领我们从视频内容采集.上传.存储 ...

  5. VR电竞游戏在英特尔®架构上的用户体验优化

    作为人与虚拟世界之间的新型交互方式,VR 能够让用户在模拟现实中获得身临其境的感受.但是,鉴于 VR 的帧预算为每帧 11.1ms (90fps),实现实时渲染并不容易,需要对整个场景渲染两次(一只眼 ...

  6. js css样式操作代码(批量操作)

    js css样式操作代码(批量操作) 作者: 字体:[增加 减小] 类型:转载 时间:2009-10-09   用js控制css样式,能让网页达到良好的的用户体验甚至是动画的效果.并且考虑到效率.   ...

  7. 界面优化--如何提升用户体验(Velocity.js和GSAP)

    Velocity.js和GSAP 我们需要提升代码质量来留住用户.作为用户界面的建设者,我们的工作是迅速引导和引导用户的注意力,指导他们如何有效地使用我们的应用程序. 1. 如何提升代码质量 定向聚焦 ...

  8. 一次基于Vue.Js的用户体验优化 (vue drag)

    一.写在前面 半年以前,第一次在项目上实践VueJs,由于在那之前,没有Angular,avalon等框架的实践经验,所以在Vue的使用上,没有给自己总结出更多的经验和体验.随着项目进行和优化改版,无 ...

  9. 网站优化JS css压缩

    在nginx 中开启gzip压缩后,可以大大减少资js css 体积,原来200KB,压缩后只有66KB server{ gzip on; gzip_types text/plain applicat ...

随机推荐

  1. Execution failed for task ':app:lintVitalRelease'.

    解决方法:在build.gradle文件的android部分添加如下代码: lintOptions { checkReleaseBuilds false abortOnError false} 最后成 ...

  2. CF1076D Edge Deletion

    洛谷传送门 cf传送门 这道题作为div.2的D题,被我一眼秒了我觉得十分荣幸,然后就开始写,然后就写了好久. AC之后看网上的题解,发现好多最短路树的,猛然发现我写的好复杂啊,结果还看到了直接一遍d ...

  3. XML学习1 xml序言 dtd约束

  4. JAVA 7新特性——在单个catch代码块中捕获多个异常,以及用升级版的类型检查重新抛出异常

    在Java 7中,catch代码块得到了升级,用以在单个catch块中处理多个异常.如果你要捕获多个异常并且它们包含相似的代码,使用这一特性将会减少代码重复度.下面用一个例子来理解. Java 7之前 ...

  5. GYM 101673F(树计数)

    树上每个割点计算一下各个size的组合相乘再相加为第一问答案,取最大的:再把本答案中最大的两个size相乘减掉,为第二问答案. const int maxn = 1e4 + 5; int n, siz ...

  6. 为VS中的括号添加虚线

    在VS中的扩展和更新中 安装Indent Guides插件,即可实现该功能.

  7. Crusher Django 学习笔记3 学习使用模板系统

    http://crusher-milling.blogspot.com/2013/09/crusher-django-tutorial3-using-template.html 顺便学习一下 goag ...

  8. 在Asp.net MVC4 中使用SimpleMembershipProvider

    一.创建MVC4项目 运行Visual Studio Express 2012 for Web,新建ASP.NET MVC4 Web 应用程序,命名为“Demo”,选择空模版.这样就创建了一个干净的M ...

  9. if __FILE__ == $0 end

    if __FILE__ == $0 end __FILE__是一个“具有魔力”的变量,它代表了当前文件名.$0是用于启动程序的文件名.那么代码“if __FILE__ == $0”便意味着检查此文件是 ...

  10. Java-IDEA环境搭建swagger

    1.项目POM导入包(使用Maven管理的代码) 2.POM文件导入包 <dependencyManagement> <dependencies> <dependency ...