【2017-04-01】JS字符串的操作、时间日期的操作、函数、事件、动画基础

一、字符串的操作

1、转大写:

s.toLowerCase();

2、转大写:

s.toUpperCase();

3、字符串的截取:

s.substr(3,4);      -从索引3开始截取,截取4位。索引从0开始。

4、将字符串按指定的字符拆开:

s.split(",");             引号内放指定的字符。返回的是一个数组。

5、字符串长度:

s.length;

6、字符串中一个字符的索引:

s.indexOf("world");      world在字符串中第一次出现的位置,返回的是索引,如果没有返回-1。

7、o在字符串中最后一次出现的位置:

s.lastIndexOf("o");

二、时间日期的操作

1、当前时间:

var d =new Date();

2、定义一个时间:

var d =new Date(1999,03,02);     1999年4月2日。

3、获取年份:d.getFullYear();     获取月份:d.getMonth();取出来的月份少1。    获取天:d.getDate();     获取星期几:d.getDay();

获取小时:d.getHours();       获取分钟:d.getMinutes();              获取秒:d.getSeconds();     设置年份:d.setFullYear();设置月份时注意加1。

三、数学函数的操作:

1、Math.ceil();       取上限

2、Math.floor();     取下限

3、Math.sqrt();      开平方

4、Math.round();     四舍五入

5、Math.random();     随机数,0-1之间。

 

四、事件

onclick           鼠标单机触发

ondblclick      鼠标双击触发

onmouseover     鼠标移入触发

onmouseout      鼠标移出触发

onmousemove     鼠标在上面移动触发

onchange         内容改变触发

onblur      失去焦点触发(焦点是指光标所在位置)

onfocus     获得交点触发

onkeydown     按下按键触发

onkeyup        抬起按键触发    可以同步显示

 

window.onload     浏览器的所有内容都加载玩以后触发,一个页面中只允许有一个onload事件,不建议使用

window.onresize    浏览器大小改变就触发

获取当前客户端宽度,高度:

window.onresize=fuction(){

var wid =document.documentElement.clientWidth;

var hei =document.documentElement.clientHeight;

}

 

阻止事件冒泡:window.event ? window.event.cancelBubble = true : e.stopPropagation();

 

 

五、动画基础

1、初步动画,匀速

 1 <!DOCTYPE html>
 2 <html xmlns="http://www.w3.org/1999/xhtml">
 3 <head>
 4     <meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
 5     <title></title>
 6     <style type="text/css">
 7         #div1 {
 8             width: 100px;
 9             height: 100px;
10             background-color: red;
11             position: absolute;
12         }
13     </style>
14 </head>
15 <body>
16     <div id="div1"></div>
17 </body>
18 </html>
19 <script type="text/javascript">
20     document.getElementById("div1").onclick = function () {
21         move(this, 300);
22     }
23     //设置一个移动的方法,需要传入两个参数:移动的对象和停止的位置
24     function move(a, end) {
25         var speed = 10;
26         //定时器window.setInterval(function(){要循环执行的代码,循环执行的时间间隔});
27         var timer = window.setInterval(function () {
28             if (a.offsetLeft + speed >= end) {
29                 a.style.left = end + "px"
30                 window.clearInterval(timer);
31             } else
32                 a.style.left = a.offsetLeft + speed + "px";           //样式表中left都带单位,别忘了赋值的时候加上单位。
33         }, 20)
34     }
35 </script>

2、初步动画,缓冲

 1 <!DOCTYPE html>
 2 <html xmlns="http://www.w3.org/1999/xhtml">
 3 <head>
 4     <meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
 5     <title></title>
 6     <style type="text/css">
 7         #div1 {
 8             width: 100px;
 9             height: 100px;
10             background-color: red;
11             position: absolute;
12         }
13     </style>
14 </head>
15 
16 <body>
17     <div id="div1"></div>
18 </body>
19 </html>
20 <script type="text/javascript">
21     document.getElementById("div1").onclick = function () {
22         move(this, 300)
23     }
24     function move(a, end) {
25         var timer = window.setInterval(function () {
26             //开始先获取一下当前位置
27             var begin = a.offsetLeft;
28             //速度用停止的位置减去当前位置除以一个数来记,速度会越来越小,以至于不够一个像素,然后给这个速度取上限,缓冲到速度为1px直到停止
29             var speed = Math.ceil((end - begin) / 30);
30             if (a.offsetLeft + speed >= end) {
31                 a.style.left = end + "px";
32                 window.clearInterval(timer);
33             }
34             else {
35                 a.style.left = a.offsetLeft + speed + "px";
36             }
37 
38         }, 20)
39     }
40 </script>

 

3、动画浮起效果

  1 <!DOCTYPE html>
  2 <html xmlns="http://www.w3.org/1999/xhtml">
  3 <head>
  4     <meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
  5     <title></title>
  6     <style>
  7         .div1 {
  8             width: 200px;
  9             height: 300px;
 10             border: 1px solid black;
 11             float: left;
 12             margin-right: 30px;
 13             margin-bottom: 30px;
 14         }
 15     </style>
 16 </head>
 17 <body>
 18     <div style="width: 100%; height: 100px;"></div>
 19     <div class="div1"></div>
 20     <div class="div1"></div>
 21     <div class="div1"></div>
 22 </body>
 23 </html>
 24 
 25 <script type="text/javascript">
 26 
 27     var oDiv1s = document.getElementsByClassName('div1');
 28 
 29     for (var i = 0; i < oDiv1s.length; i++) {
 30         oDiv1s[i].index = i;
 31         oDiv1s[i].onmouseover = function () {
 32             up(this, this.index);
 33         }
 34         oDiv1s[i].onmouseout = function () {
 35             down(this, this.index);
 36         }
 37     }
 38 
 39     //放置所有元素的定时器数组
 40     var timers = new Array();
 41 
 42     //浮起,a:要执行动画的对象,ind:对象的索引
 43     function up(a, ind) {
 44         //清空此对象当前所有的动画效果
 45         window.clearInterval(timers[ind]);
 46 
 47         //获取此对象当前的上边距
 48         var mtop = a.style.marginTop;
 49         var t = 0;//设置默认值为
 50         if (mtop.length > 0) {//如果当前对象有上边距,那么修改默认值
 51             //将“25px”这样的格式数据截取出值
 52             t = parseInt(mtop.substr(0, mtop.length - 2));
 53         }
 54 
 55         //当前阴影值获取,思路同上
 56         var bshadow = a.style.boxShadow;
 57         var b = 0;
 58         if (bshadow.length > 0) {
 59             var bb = bshadow.split(' ');
 60             b = parseInt(bb[bb.length - 1].substr(bb[bb.length - 1] - 2));
 61         }
 62 
 63         //定时器开启,并将此定时器放入定时器集合中
 64         timers[ind] = window.setInterval(function () {
 65             t--;//上边距改变
 66             b++;//阴影扩散程度改变
 67             if (t <= -25 && b >= 25) {//停止条件
 68                 //停止时将元素锁定在目标位置
 69                 a.style.marginTop = '-25px';
 70                 a.style.boxShadow = "0 0 25px gray";
 71                 window.clearInterval(timers[ind]);
 72             }
 73             else {
 74                 //动画执行
 75                 a.style.marginTop = t + 'px';
 76                 a.style.boxShadow = "0 0 " + b + "px gray";
 77             }
 78         }, 20);
 79 
 80     }
 81 
 82     //下降,a:要执行动画的对象,ind:对象的索引
 83     function down(a, ind) {
 84         //清空此对象当前所有的动画效果
 85         window.clearInterval(timers[ind]);
 86 
 87         //获取此对象当前的上边距
 88         var mtop = a.style.marginTop;
 89         var t = -25;//设置默认值为
 90         if (mtop.length > 0) {//如果当前对象有上边距,那么修改默认值
 91             //将“25px”这样的格式数据截取出值
 92             t = parseInt(mtop.substr(0, mtop.length - 2));
 93         }
 94 
 95         //当前阴影值获取,思路同上
 96         var bshadow = a.style.boxShadow;
 97         var b = 0;
 98         if (bshadow.length > 0) {
 99             var bb = bshadow.split(' ');
100             b = parseInt(bb[bb.length - 1].substr(bb[bb.length - 1] - 2));
101         }
102 
103         //定时器开启,并将此定时器放入定时器集合中
104         timers[ind] = window.setInterval(function () {
105             t++;//上边距改变
106             b--;//阴影扩散程度改变
107             if (t >= 0 && b <= 0) {//停止条件
108                 a.style.marginTop = '0px';
109                 a.style.boxShadow = "0 0 0px gray";
110                 window.clearInterval(timers[ind]);
111             }
112             else {
113                 //动画执行
114                 a.style.marginTop = t + 'px';
115                 a.style.boxShadow = "0 0 " + b + "px gray";
116             }
117         }, 20);
118 
119     }
120 
121 
122 
123 </script>

 

posted @ 2017-04-03 21:46  疯丶无度  阅读(674)  评论(0编辑  收藏  举报