前端用户体验优化: JS & CSS 各类效果代码段
前言
- 不定时更新
- 在线预览 https://zzyper.github.io/opti...
- 在线预览的源码 https://github.com/zzyper/opt...
- 部分内容仅兼容
webkit内核,其他内核自行查询
可控密度的虚线分隔线 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 各类效果代码段的更多相关文章
- Vue.Js的用户体验优化
一次基于Vue.Js的用户体验优化 一.写在前面 半年以前,第一次在项目上实践VueJs,由于在那之前,没有Angular,avalon等框架的实践经验,所以在Vue的使用上,没有给自己总结出更多 ...
- Google Pagespeed,自动压缩优化JS/CSS/Image
Google Pagespeed,自动压缩优化JS/CSS/Image 浏览: 发布日期:// 分类:技术分享 关键字: Nginx Appache Pagespeed 自动压缩优化JS/CSS/Im ...
- [ionic开源项目教程] - 第10讲 新闻详情页的用户体验优化
目录 [ionic开源项目教程] 第1讲 前言,技术储备,环境搭建,常用命令 [ionic开源项目教程] 第2讲 新建项目,架构页面,配置app.js和controllers.js [ionic开源项 ...
- CDN高级技术专家周哲:深度剖析短视频分发过程中的用户体验优化技术点
深圳云栖大会已经圆满落幕,在3月29日飞天技术汇-弹性计算.网络和CDN专场中,阿里云CDN高级技术专家周哲为我们带来了<海量短视频极速分发>的主题分享,带领我们从视频内容采集.上传.存储 ...
- VR电竞游戏在英特尔®架构上的用户体验优化
作为人与虚拟世界之间的新型交互方式,VR 能够让用户在模拟现实中获得身临其境的感受.但是,鉴于 VR 的帧预算为每帧 11.1ms (90fps),实现实时渲染并不容易,需要对整个场景渲染两次(一只眼 ...
- js css样式操作代码(批量操作)
js css样式操作代码(批量操作) 作者: 字体:[增加 减小] 类型:转载 时间:2009-10-09 用js控制css样式,能让网页达到良好的的用户体验甚至是动画的效果.并且考虑到效率. ...
- 界面优化--如何提升用户体验(Velocity.js和GSAP)
Velocity.js和GSAP 我们需要提升代码质量来留住用户.作为用户界面的建设者,我们的工作是迅速引导和引导用户的注意力,指导他们如何有效地使用我们的应用程序. 1. 如何提升代码质量 定向聚焦 ...
- 一次基于Vue.Js的用户体验优化 (vue drag)
一.写在前面 半年以前,第一次在项目上实践VueJs,由于在那之前,没有Angular,avalon等框架的实践经验,所以在Vue的使用上,没有给自己总结出更多的经验和体验.随着项目进行和优化改版,无 ...
- 网站优化JS css压缩
在nginx 中开启gzip压缩后,可以大大减少资js css 体积,原来200KB,压缩后只有66KB server{ gzip on; gzip_types text/plain applicat ...
随机推荐
- scrapy分布式原理
scrapy分布式原理 关于Scrapy工作流程回顾 Scrapy单机架构 上图的架构其实就是一种单机架构,只在本机维护一个爬取队列,Scheduler进行调度,而要实现多态服务器共同爬取数据关键 ...
- Java EE学习笔记(五)
Spring事务管理 1.Spring事务管理概述 1).在实际开发中,操作数据库时都会涉及到事务管理问题,为此Spring提供了专门用于事务处理的API.(事务特性:ACID,原子性,一致性,隔离性 ...
- mysql 维护添加远程主机访问
https://www.cnblogs.com/JNUX/p/6936548.html
- JAVA常用知识总结(十二)——数据库(二)
MySQL主从热备份工作原理 简单的说:就是主服务器上执行过的sql语句会保存在binLog里面,别的从服务器把他同步过来,然后重复执行一遍,那么它们就能一直同步啦. 整体上来说,复制有3个步骤: 作 ...
- Spring Security – security none, filters none, access permitAll
1.概述 Spring Security提供了几种将请求模式配置为不安全或允许所有访问的机制.取决于这些机制中的哪一种 - 这可能意味着根本不在该路径上运行安全过滤器链,或者运行过滤器链并允许访问 2 ...
- ruby字符串处理
1. str="abc123"puts str[0].chr => a puts str[0] =>a的ascii码 2.中文字符串的正则 ...
- 最大流bfs
#include<iostream> #include<cstdio> #include<cstring> #include<algorithm> #i ...
- poj 2406 Power Strings 周期问题
Power Strings Time Limit: 3000MS Memory Limit: 65536K Total Submissions: 48139 Accepted: 20040 D ...
- 2840 WIKIOI——评测
2840 WIKIOI——评测 时间限制: 1 s 空间限制: 2000 KB 题目等级 : 白银 Silver 题目描述 Description Wikioi上有一题有N个测试点,时限为 ...
- Sql 行转换为列 以及列转换为行的心得
这是 创建数据库的脚本文件 CREATE TABLE [dbo].[stu]( [学号] [nvarchar](255) NOT NULL, [姓名] [nvarchar](255) NULL, [性 ...