前言

可控密度的虚线分隔线 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. 51Nod 1099 任务执行顺序 (贪心)

    #include <iostream> #include <algorithm> using namespace std; +; struct node{ int r, q; ...

  2. DHCP snooping(DHCP监听)

    DHCP监听可以防范利用DHCP发起的多种攻击行为,如DHCP中间人攻击,伪造多台设备耗尽地址池 DHCP监听允许可信端口上的所有DHCP消息,但是却过滤非可信端口上的DHCP消息,DHCP监听还会在 ...

  3. bzoj 2441 [中山市选2011]小W的问题

    bzoj 2441 [中山市选2011]小W的问题 Description 有一天,小W找了一个笛卡尔坐标系,并在上面选取了N个整点.他发现通过这些整点能够画出很多个"W"出来.具 ...

  4. GYM 101889J(枚举、环上gcd)

    答案只有n - 1种暴举即可,对于每种,gcd是一那踩雷稳了,否则看雷的分布有没有把模余占满. const int maxn = 1e5 + 5; int n, ans; char str[maxn] ...

  5. Ionic之button标签ng-click无反应解决

    在使用Ionic中,使用按钮的ng-click事件,竟然点击没有反应,刚开始以为自己写得方法有问题才会不起作用,自己在点击之后就console.log()一个东西,但是console也是无法反应的.& ...

  6. Negut 上传乱码

    解决办法 修改 bat  文件的 格式为ANSI格式即可

  7. sql server技巧

    --查出数据最新的存储过程select name,modify_date from sys.procedures where modify_date>'2017-05-26 17:21:09.3 ...

  8. 生鲜o2o配送应用系统,包括Android源码+SSH带后台管理系统

    前台功能划分    我的 登录            账户+密码 注册            订单管理 查看/删除(显示订单详情)                支付(提交订单)           ...

  9. javascript基本类型和引用类型,作用域和内存问题

    基本类型(null.undefined.boolean.number.string)和引用类型(Object 对象) 1  基本类型:只能不存一个值,一种类型:从一个变量向另一个变量复制基本类型的值, ...

  10. Gym 100342I Travel Agency (Tarjan)

    题意读懂了就好做了,就是求一下点双连通分量.维护一下一颗子树的结点数,对于一个结点当u是割点的时候, 统计一下u分割的连通分量v,每得到一个连通分量的结点数cnt(v)和之前连通分量结点数sum相乘一 ...