JS-特效 ~ 05. 缓动框架兼容封装/回掉函数/兼容透明度/层级、旋转轮播图、正则表达式、验证表单注册账号、
- 缓动函数中opcity 写百分值的值
- JS一般不用小数运算,会照成精度丢失
- 元素的默*认透明度是
- 层级一次性赋值,不缓动
- 利用for…in为同一个父元素的子元素绑定属性
缓动框架兼容封装/回掉函数/兼容透明度/层级
function animate(ele,json,fn){
//先清定时器
clearInterval(ele.timer);
ele.timer = setInterval(function () {
//开闭原则
var bool = true;
//遍历属性和值,分别单独处理json
//attr == k(键) target == json[k](值)
for(var k in json){
//四部
var leader;
//判断如果属性为opacity的时候特殊获取值
if(k === "opacity"){
leader = getStyle(ele,k)*100 || 1;
}else{
leader = parseInt(getStyle(ele,k)) || 0;
}
//1.获取步长
var step = (json[k] - leader)/10;
//2.二次加工步长
step = step>0?Math.ceil(step):Math.floor(step);
leader = leader + step;
//3.赋值
//特殊情况特殊赋值
if(k === "opacity"){
ele.style[k] = leader/100;
//兼容IE678
ele.style.filter = "alpha(opacity="+leader+")";
//如果是层级,一次行赋值成功,不需要缓动赋值
//为什么?需求!
}else if(k === "zIndex"){
ele.style.zIndex = json[k];
}else{
ele.style[k] = leader + "px";
}
//4.清除定时器
//判断: 目标值和当前值的差大于步长,就不能跳出循环
//不考虑小数的情况:目标位置和当前位置不相等,就不能清除清除定时器。
if(json[k] !== leader){
bool = false;
}
}
console.log(1);
//只有所有的属性都到了指定位置,bool值才不会变成false;
if(bool){
clearInterval(ele.timer);
//所有程序执行完毕了,现在可以执行回调函数了
//只有传递了回调函数,才能执行
if(fn){
fn();
}
}
},25);
}
//兼容方法获取元素样式
function getStyle(ele,attr){
if(window.getComputedStyle){
return window.getComputedStyle(ele,null)[attr];
}
return ele.currentStyle[attr];
}
旋转轮播图
http://mingm.top/demo/04-旋转轮播图/demo.html
https://github.com/q878067583/mingm/tree/gh-pages/demo/04-旋转轮播图
在数组json中,删除第一个元素,添加到最末尾。(正转)
在数组json中,删除最后一个元素,添加到第一位。(反转)
正则表达式:
本质:用来记录文本规则的代码,
可以迅速地用极简单的方式达到字符串的复杂控制。
Regular Expression
定义方法
var reg = new RegExp (/abs/) ;
var reg = /abc/ ;
Boolean = 表达式.test("要验证的内容");检测是否符合正则表达式“reg”的要求,并返回true/false ;
正则表达式的组成是:(总结)
有一些普通字符和元字符组成,普通字符就是字母和数字,元字符具有特殊意义的字符
匹配腾讯QQ号:[1-9][0-9]{4,}
评注:腾讯QQ号从10000开始
比如 \d
预定义类: 表示数字 [0-9]
正则内部类:
预定义类
. [^\n\r] 除了换行和回车之外的任意字符
\d [0-9] 数字字符 \s [\t\n\x0B\f\r] 空白字符. \w [a-zA-Z_0-9] 单词字符
\D [^0-9]非数字字符 \S [^\t\n\x0B\f\r] 非空白字符 \W [^a-zA-Z_0-9] 非单词字符
简单类(正则://中什么特殊符号都不写,和[]的加入)
/string/.test(“string”); 必须是完整的,只多不能少
/andy/.test(“andy”) // true
一句话,只要完整包含了andy 就可以了(有他就行)
/[string]/.test(“string”); 只要包含里面的任何一个就可以
负向类
/[^abc]/.test(ds):不能含有abc任意一个字符
- 不够和正好返回false,多了返回true,
- /[^abc]/.test(“aiiiii”)返回true
- /[^abc]/.test(“a”)返回fals
范围类
有时匹配的东西过多,而且类型又相同,全部输入太麻烦,我们可以在中间加了个横线
console.log(/[a-z]/.test('1111'));
console.log(/[A-Z]/.test('aa'));
组合类
用中括号匹配不同类型的单个字符。
console.log(/[a-m1-5]/.test("b"))//true
正则边界:
^ 会匹配行或者字符串的起始位置
注:^在[]中才表示非!这里表示开始
$ 会匹配行或字符串的结尾位置
^$在一起 表示必须是这个(精确匹配)
// 边界可以精确说明要什么
console.log(/lily/.test("lilyname")); // true
console.log(/^lily$/.test("lily")); // true
console.log(/^lily$/.test("ly")); // false
console.log(/^andy$/.test("andy")); // true
这个的最终意思就是 说, 必须是 andy 这四个字母
量词:
(多个字母,重复最后一个)
* (贪婪) 重复零次或更多 (>=0)
+ (懒惰) 重复一次或更多次 (>=1)
? (占有) 重复零次或一次 (0||1) 要么有 要么没有
{} 重复多少次的意思 可以有多少个
您的银行卡密码只能是 6位 {6}
{n} n次 (x=n)
{n,} 重复n次或更多 (x>=n)
{n,m} 重复出现的次数比n多但比m少 (n<=x<=m)
* {0,}
+ {1,}
? {0,1}
x|y 一个 | x 或者 y(没有&,用的是,代替的)
()提高权限,有限计算
replace() 去除空格,
var str = " 你好,我 很好! ";
console.log(str);
// console.log(str.trim());
console.log(trim(str));
function trim(str){
var aaa = str.replace(/(^\s+)|(\s+$)/g,"");
return aaa;
}
表单验证css模版
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Document</title>
</head>
<style type="text/css">
body {
background: #ccc;
} label {
width: 40px;
display: inline-block;
} .container {
margin: 100px auto;
width: 400px;
padding: 50px;
line-height: 40px;
border: 1px solid #999;
background: #efefef;
} span {
margin-left: 30px;
font-size: 12px;
padding:2px 20px 0;
color: #ccc;
} .wrong {
color: red;
background: url(images/error.png) no-repeat; } .right {
color: green;
background: url(images/right.png) no-repeat;
} .pwd {
width: 220px;
height: 20px;
background: url("images/strong.jpg") no-repeat;
}
.str1{
background-position: 0 -20px;
}
.str2{
background-position: 0 -40px;
}
.str3{
background-position: 0 -60px;
}
.str4{
background-position: 0 -80px;
}
</style> <script>
window.onload = function () {
//需求:按照需求,对表单数据进行校验!
//步骤:
//1.老三步
//2.判断是否符合正则标准
//3.给样式。(封装方法给) // var inp1 = document.getElementById("inp1");
// var inp2 = document.getElementById("inp2");
// var inp3 = document.getElementById("inp3");
// var inp4 = document.getElementById("inp4");
// var inp5 = document.getElementById("inp5");
// var inp6 = document.getElementById("inp6");
var password = document.getElementById("password"); // inp1.onblur = function () {
// var span = this.nextElementSibling || this.nextSibling;
// if(/^[1-9][0-9]{4,}$/.test(this.value)){
// span.innerHTML = "恭喜您,输入正确!";
// span.className = "right";
// }else{
// span.innerHTML = "格式错误!";
// span.className = "wrong";
// }
// } //qq号
addEvent("inp1", function () {
if(/^[1-9][0-9]{4,}$/.test(this.value)){
setClassName(this,"right");
setInnerHTML(this,"恭喜您,输入正确!");
}else{
setClassName(this,"wrong");
setInnerHTML(this,"格式错误!");
}
}); //手机号
addEvent("inp2", function () {
if(/^((13[0-9])|(15[^4,\D])|(18[0-9]))\d{8}$/.test(this.value)){
setClassName(this,"right");
setInnerHTML(this,"恭喜您,输入正确!");
}else{
setClassName(this,"wrong");
setInnerHTML(this,"格式错误!");
}
}); //邮箱
addEvent("inp3", function () {
if(/^[\w\-\.]{5,}\@[\w]+\.[\w]{2,4}$/.test(this.value)){
setClassName(this,"right");
setInnerHTML(this,"恭喜您,输入正确!");
}else{
setClassName(this,"wrong");
setInnerHTML(this,"格式错误!");
}
}); //座机
addEvent("inp4", function () {
if(/(^0\d{2}-8\d{7}$)|(^0\d{3}-3\d{6}$)/.test(this.value)){
setClassName(this,"right");
setInnerHTML(this,"恭喜您,输入正确!");
}else{
setClassName(this,"wrong");
setInnerHTML(this,"格式错误!");
}
}); //用户名
addEvent("inp5", function () {
if(/^[a-zA-Z0-9_-]{3,16}$/.test(this.value)){
setClassName(this,"right");
setInnerHTML(this,"恭喜您,输入正确!");
}else{
setClassName(this,"wrong");
setInnerHTML(this,"格式错误!");
}
}); //密码
addEvent("inp6", function () {
if(/^[a-zA-Z0-9_\-$]{6,18}$/.test(this.value)){
setClassName(this,"right");
setInnerHTML(this,"恭喜您,输入正确!");
password.className = "pwd str1";
//只有密码通过了,才能执行密码强度测试
//从大往小判断。
if(/^[A-Za-z0-9]+[_$][A-Za-z0-9]*$/.test(this.value)){
password.className = "pwd str4";
}else if(/^([a-z].*[0-9])|([A-Z].*[0-9])|[0-9].*[a-zA-Z]$/.test(this.value)){
password.className = "pwd str3";
}else if(/^([a-z].*[A-Z])|([A-Z].*[a-z])$/.test(this.value)){
password.className = "pwd str2";
} }else{
setClassName(this,"wrong");
setInnerHTML(this,"格式错误!");
}
}); //因为每次都要这样调用,所以很繁琐,我们通过封装实现代码
function addEvent(str,fn){
document.getElementById(str).onblur = fn;
} function setClassName(aaa,txt){
var span = aaa.nextElementSibling || this.nextSibling;
span.className = txt;
}
function setInnerHTML(aaa,txt){
// console.log(this);
var span = aaa.nextElementSibling || this.nextSibling;
span.innerHTML = txt;
}
}
</script> <body>
<div class="container">
<label for="inp1">QQ</label><input type="text" id="inp1"><span>输入正确的QQ号码</span><br>
<label for="inp2">手机</label><input type="text" id="inp2"><span>输入13位手机号码</span><br>
<label for="inp3">邮箱</label><input type="text" id="inp3"><span>输入正确邮箱</span><br>
<label for="inp4">座机</label><input type="text" id="inp4"><span>输入您的座机</span><br>
<label for="inp5">账号</label><input type="text" id="inp5"><span>亲输入您的账号</span><br>
<label for="inp6">密码</label><input type="text" id="inp6"><span>请输入您的密码</span><br>
<div id="password" class="pwd"></div>
</div>
</body>
</html>
JS-特效 ~ 05. 缓动框架兼容封装/回掉函数/兼容透明度/层级、旋转轮播图、正则表达式、验证表单注册账号、的更多相关文章
- JS正则表达式验证表单
一.解释一些符号相关的意义 1. /^$/ 这个是个通用的格式. ^ 匹配输入字符串的开始位置:$匹配输入字符串的结束位置 2. 里面输入需要实现的功能. ...
- JS特效@缓动框架封装及应用
| 版权声明:本文为博主原创文章,未经博主允许不得转载. 一.变量CSS样式属性获取/赋值方法 给属性赋值:(既能获取又能赋值) 1)div.style.width 单个赋值:点语法,这个方法比较固定 ...
- JS——缓动框架的问题
1.opacity问题:IE678支持filter: alpha(opacity=50)取值1-100:小数位容易精度丢失,所i有统一json字符串设置为百进制,赋值时除以100 2.zIndex问题 ...
- JS封装动画框架,网易轮播图,旋转轮播图
JS封装动画框架,网易轮播图,旋转轮播图 1. JS封装运动框架 // 多个属性运动框架 添加回调函数 function animate(obj,json,fn) { clearInterval(ob ...
- 原生js封装ajax:传json,str,excel文件上传表单提交
由于项目中需要在提交ajax前设置header信息,jquery的ajax实现不了,我们自己封装几个常用的ajax方法. jQuery的ajax普通封装 var ajaxFn = function(u ...
- Thinkphp3.2.3框架下封装公共的函数,例如封装CURL函数来获取接口数据
当我们需要在控制层调用相同的封装函数时,写多次相同的函数,显得代码十分的拉杂,不精简: TP框架有一个很好的机制,可以再Common定义一个function.php函数,当我们在控制层调用的时候直接调 ...
- 原生JS实现旋转轮播图+文字内容切换
废话不多说,直接上图看效果: 需求:点击左右按钮实现切换用户图片与信息: 原理:点击右侧左侧按钮,把3号的样式给2号,2号的给1号,1号的给5号,5号的给4号,4号的样式给3号,然后根据现在是第几张图 ...
- tp框架之自动验证表单
tp框架的create自动加载表单的方法可以自动根据自己定义的要求来验证表单里面的内容,但是由于是在后台执行代码,会拖慢程序运行速度,所以还是建议通过前端js来进行判断,后台只进行数据库的查询以及传值 ...
- js验证表单大全
js验证表单大全 1. 长度限制 <script> function test() { if(document.a.b.value.length>50) { alert(" ...
随机推荐
- JavaSE之——并没有多维数组
近日在读<疯狂Java讲义>精粹第二版,部分语述摘自其中,自己边敲边理解 前言 我们知道,Java语言支持的类型有两种: 1.基本类型(即八大基本数据类 ...
- Hadoop 系列(二)—— 集群资源管理器 YARN
一.hadoop yarn 简介 Apache YARN (Yet Another Resource Negotiator) 是 hadoop 2.0 引入的集群资源管理系统.用户可以将各种服务框架部 ...
- MySQL一键生成实体文件的神器-ginbro
Java转过来的同学对Mybatis的使用肯定不陌生,特别是对一堆表去生成相应的dao和entity的时候使用Mybatis generator所带来的感触,无比深刻.前面我们也讲过原生的数据库使用, ...
- SpringBoot学习系列之一(反射)
最近在学习SpringBoot的知识,动起手来学习的时候才发现SpringBoot项目采用了大量的反射机制,晕,作为一个应届毕业生,以前学习反射的时候给我的感觉就是,这个到底用来干嘛的,好像没啥用啊, ...
- 【Kubernetes 系列二】从虚拟机讲到 Kubernetes 架构
目录 什么是虚拟机? 什么是容器? Docker Kubernetes 架构 Kubernetes 对象 基础设施抽象 在认识 Kubernetes 之前,我们需了解下容器,在了解容器之前,我们得先知 ...
- Ubuntu 18.04 LTS版本 GoldenDict安装与配置
为何安装? GoldenDict是一款Linux下很好用的词典软件,其具有的关于词典的裁剪功能使得用户能够方便地对各种词典进行添加或删除,其具有的屏幕取词功能能够帮助用户方便地进行翻译,其具有的网络源 ...
- java面向对象中的集合
1.学习集合的原因? A.数组是面向过程的,集合是面向对象的. B.集合是类,具备类的封装,继承,多态...超强功能. C.数组是固定长度,集合是可变长度 D.数组没办法获得真实的元素个数:集合可以. ...
- 前端插件之Datatables使用--下篇
工欲善其事,必先利其器 本系列文章介绍我在运维系统开发过程中用到的那些顺手的前端插件,上一篇文章介绍了Datatables插件的基本使用,这一篇文章作为上一篇的延续,会介绍Databases的一些高级 ...
- Redis缓存,持久化,高可用
一,Redis作缓存服务器 本篇博客是接着上一篇博客未分享完的技术点. redis作为缓存服务器是众多企业中的选择之一,虽然该技术很成熟但也是存在一定的问题.就是缓存带来的缓存穿透,缓存击穿, ...
- MUI-页面传参数
点击第一个页面的标签,跳转到第二个页面,把第一个页面的值也传往目标页面 现在提供两种实现方式 注意:需要在手机运行才可以,用电脑浏览器可能不支持. 第一种方式 页面已创建,通过自定义事件传值 fir ...