主要解决的是前端与用户交互的问题,包括使用交互与数据交互。javascript是浏览器解释执行的,前端脚本还有Jscript(微软、IE独有),ActionScript(Adobe公司,需要插件)等。
前端三大块:
HTML:页面结构
CSS:页面表现;元素大小、颜色、位置、隐藏或显示、部分动画效果
JavaScript的变量类型由它的值来决定。定义变量需要用关键字‘var’
var iNum = 123;
var sTr = ‘abc’;
变量类型
基本数据类型:
number数字类型;string字符串类型;boolean布尔类型true或false;undefined undefined类型、变量声明未初始化,它的值就是undefined;null null类型,表示空对象,如果定义的变量将来准备保存对象,可以将变量初始化为null,在页面上获取不到对象,返回的值就是null。
复合类型:
object
JavaScript中,一条语句用“;”结尾。
//为单行注释;/* kdf */为多行注释
命名规范:区分大小写;第一个字符必须是字母、下划线(_)或者美元符号($);其他字符可以是字母、下划线、美元符或数字
内置对象document上的getElementByld方法来获取页面上设置了id属性的元素,获取到的是一个html对象,然后将它赋值给一个变量。
JavaScript语句如果写在元素的上面,就会出错,因为页面是从上向下执行的。
解决方法:
1>将JavaScript放到页面最下边
2>将JavaScript语句放到Windows.onload触发的函数里面,获取元素的语句会在页面加载完后才执行,就不会出错了。
操作元素的方法:
1> “.”操作 2> “[ ]”操作
属性写法:
1>html的属性和js里面属性写法一样
2>“class”属性协程“className”
3>“style”属性里面的属性,有横杆的改成驼峰式,比如:“font-size”,改成“style.fontSize”
innerHTML
innerHTML可以读取或者写入标签包裹的内容
重复执行的代码片。
JavaScript解析分为两个阶段,先是编译阶段,然后执行阶段。在编译阶段会将function定义的函数提前,并且将var定义的变量声明提前,将它赋值为undefined
在html行间调用的事件可以提取到JavaScript中调用,从而做到结构与行为分离。
定义的函数可以不给名称,这个叫做匿名函数,可以将匿名函数直接赋值给元素绑定的事件来完成匿名函数的调用。
函数中‘return’关键字的作用:
a 返回函数执行的结果
b 结束函数的运行
c 阻止默认行为
运算符
1>算术:+、-、*、/
2>赋值:=、+=、-=、*=、/=、%、
3>条件:==、===、>、>=、<、<=、!=、&&、||、!
==
有类型转换 2(整数)和‘2’(字符串),会出现相等的结果
===
没有类型转换
if else
if(iNum01>iNum02){
sTr = '大于';
}
else
{
sTr = '小于';
}
switch语句
switch (iNow){
case 1:
...;
break;
case 2:
...;
break;
default:
...;
}
数组就是一组数据的集合,JavaScript中,数组里面的数据可以是不同类型的。
var 数组名 = new Array(数据1,数据2,…)
var 数组名 = [数据1,数据2,…]
a 获取数组的长度
数组名.length
b 用下标操作数组的某个数据
数组名[0]
c join()将数据成员通过一个分隔符合并成字符串
数组名.join(‘-’)
d push()和pop()从数组最后增加成员或删除成员
e unshift()和shift()从数组前面增加成员或删除成员
f reverse() 将数组反转
g indexOf()返回数组中元素第一次出现的索引值
h splice()在数组中增加或删除成员
ar aList = [1,2,3,4];
aList.splice(2,1,7,8,9); //从第2个元素开始,删除1个元素,然后在此位置增加’7,8,9’三个元素
alert(aList); //弹出 1,2,7,8,9,4
数组中定义数组即可
for(var i=0;i
while(条件){
…
i++;
}
定义一个空数组,写一个双循环,使用indexOf()函数,判断是否和当前下标相等,如果相等,就加入到空数组中。
可以使用内置对象document上的getElementsByTagName方法来获取页面上的某一种标签,获取的是一个选择集,不是数组,但是可以用下标的方式操作选择集里的元素。
1>ECMAscript javascrip的语法(变量、函数、循环语句等语法)
2>DOM文档对象模型 操作html和css的方法
3>BOM浏览器对象模型 操作浏览器的一些方法
1>字符串合并操作“+”
2>parselnt()将数字字符串转化为整数
3>parseFloat()将数字字符串转化为小数
4>split()把一个字符串分隔成字符串组成的数组
5>charAt()获取字符串中的某一个字符
6>indexOf()查找字符串是否含有某字符
7>substring()截取字符串 用法:substring(start,end)(不包括end)
8>toUpperCase()字符串转大写
9>toLowerCase()字符串转小写
10>字符串反转
str.split(‘’).reverse().join(‘’);
split将字符串切为数组,使用reverse函数反转,再用join合并为字符串。
1>直接转换parselnt()与parseFloat()
2>隐式转换“==”和“-” 这两个字符会自动进行类型转换
3>NaN和isNaN
1>alert
2>console.log
3>document.title
1>定时器在javascript中的作用
制作动画;异步操作;函数缓冲与节流
2>定时器类型及语法
setTimeout 只执行一次的定时器
clearTimeout 关闭只执行一次的定时器
setInterval 反复执行的定时器
clearInterval 关闭反复执行的定时器
var time1 = setTimeout(myalert,2000);
第一个参数是执行的函数,第二个是时间,单位为毫秒
变量的作用范围,javascript中的变量分为全局变量和局部变量。
全局变量:在函数之外定义的变量,为整个页面公用,函数内部外部都可以访问。
局部变量:在函数内部定义的变量,只能在定义该变量的函数内部访问,外部无法访问。
javascript中匿名函数的另外一种写法,创建一个一开始就执行而不用命名的函数。
(function myalert(){
alert('hello!');
})();
匿名函数的好处:可以创造一个独立的空间,在封闭函数内定义的变量和函数不会影响外部同名的函数和变量,可以避免命名冲突,在页面上引入多个js文件时,用这种方式添加js文件比较安全。
document.getElementById //通过id获取元素
document.getElementsByTagName //通过标签名获取元素
document.referrer //获取上一个跳转页面的地址(需要服务器环境)
window.location.href //获取或者重定url地址
window.location.search //获取地址参数部分
window.location.hash //获取页面锚点或者叫哈希值
Math.random 获取0-1的随机数
Math.floor 向下取整
Math.ceil 向上取整
jquery是一个函数库,一个js文件,页面用script标签引入这个js文件就可以使用。
将获取元素的语句写到页面头部,会因为元素还没有加载而出错,jquery提供了ready方法解决这个问题,它的速度比原生的 window.onload 更快。
jquery用法思想一:选择某个网页元素,然后对它进行某种操作
可以快速地选择元素,选择规则和css样式相同,使用length属性判断是否选择成功
$('li') //选择所有的li元素
$('#ul1 li span') //选择id为为ul1元素下的所有li下的span元素
$('div').has('p'); // 选择包含p元素的div元素
$('div').not('.myClass'); //选择class不等于myClass的div元素
$('div').filter('.myClass'); //选择class等于myClass的div元素
$('div').eq(5); //选择第6个div元素
$('div').prev(); //选择div元素前面紧挨的同辈元素
$('div').prevAll(); //选择div元素之前所有的同辈元素
$('div').next(); //选择div元素后面紧挨的同辈元素
$('div').nextAll(); //选择div元素后面所有的同辈元素
$('div').parent(); //选择div的父元素
$('div').children(); //选择div的所有子元素
$('div').siblings(); //选择div的同级元素
$('div').find('.myClass'); //选择div内的class等于myClass的元素
length为0就是没有选择到元素,大于0就是选择到了元素。
jquery用法思想二:同一个函数完成取值和赋值
// 获取div的样式
$("div").css("width");
$("div").css("color");
//设置div的样式
$("div").css("width","30px");
$("div").css("height","30px");
$("div").css({fontSize:"30px",color:"red"});
$("#div1").addClass("divClass2") //为id为div1的对象追加样式divClass2
$("#div1").removeClass("divClass") //移除id为div1的对象的class名为divClass的样式
$("#div1").removeClass("divClass divClass2") //移除多个样式
$("#div1").toggleClass("anotherClass") //重复切换anotherClass样式
$('#btn1').click(function(){
// 内部的this指的是原生对象
// 使用jquery对象用 $(this)
})
var $li = $('.list li').eq(1);
alert($li.index()); // 弹出1
......
- 1
- 2
- 4
- 5
- 6
fadeIn() 淡入
$btn.click(function(){
$('#div1').fadeIn(1000,'swing',function(){
alert('done!');
});
1000为时间,单位为毫秒;‘swing’为缓冲运动
});
fadeOut() 淡出
fadeToggle() 切换淡入淡出
hide() 隐藏元素
show() 显示元素
toggle() 切换元素的可见状态
slideDown() 向下展开
slideUp() 向上卷起
slideToggle() 依次展开或卷起某个元素
jquery对象的方法会在执行完后返回这个jquery对象,所有jquery对象的方法可以连起来写:
$('#div1') // id为div1的元素
.children('ul') //该元素下面的ul子元素
.slideDown('fast') //高度从零变到实际高度来显示ul元素
.parent() //跳到ul的父元素,也就是id为div1的元素
.siblings() //跳到div1元素平级的所有兄弟元素
.children('ul') //这些兄弟元素中的ul子元素
.slideUp('fast'); //高度实际高度变换到零来隐藏ul元素
通过animate方法可以设置元素某属性值上的动画,可以设置一个或多个属性值,动画执行完成后会执行一个函数。
$('#div1').animate({
width:300,
height:300
},1000,'swing',function(){
alert('done!');
});
width()、height() 获取元素width和height
innerWidth()、innerHeight() 包括padding的width和height
outerWidth()、outerHeight() 包括padding和border的width和height
outerWidth(true)、outerHeight(true) 包括padding和border以及margin的width和height
offset()
$(window).width();
$(window).height();
$(document).width();
$(document).height();
$(document).scrollTop();
$(document).scrollLeft();
$(window).scroll(function(){
......
})
1>html()取出或设置html内容
// 取出html内容
var $htm = $('#div1').html();
// 设置html内容
$('#div1').html('添加文字');
2>prop()取出或设置某个属性的值
// 取出图片的地址
var $src = $('#img1').prop('src');
// 设置图片的地址和alt属性
$('#img1').prop({src: "test.jpg", alt: "Test Image" });
对jquery选择的对象集合分别进行操作,需要用到jquery循环操作,此时可以用对象上的each方法
$(function(){
$('.list li').each(function(i){
$(this).html(i);
})
})
blur() 元素失去焦点
focus() 元素获得焦点
click() 鼠标单击
mouseover() 鼠标进入(进入子元素也触发)
mouseout() 鼠标离开(离开子元素也触发)
mouseenter() 鼠标进入(进入子元素不触发)
mouseleave() 鼠标离开(离开子元素不触发)
hover() 同时为mouseenter和mouseleave事件指定处理函数
ready() DOM加载完成
resize() 浏览器窗口的大小发生改变
scroll() 滚动条的位置发生变化
submit() 用户递交表单
$(function(){
$('#div1').bind('mouseover click', function(event) {
alert($(this).html());
});
});
$(function(){
$('#div1').bind('mouseover click', function(event) {
alert($(this).html());
// $(this).unbind();
$(this).unbind('mouseover');
});
});
在一个对象上触发某类事件(如单击),如果此对象定义了此事件的处理程序,那么此事件就会调用这个处理程序,如果没有定义此事件处理程序或者事件返回true,那么这个事件会向这个对象的父级对象传播,从里到外,直至它被处理(父级对象所有同类事件都将被激活),或者它到达了对象层次的最顶层,即document对象。
事件冒泡允许多个操作被集中处理(把事件处理器添加到一个父类元素上,避免把事件处理器添加到多个子级元素上),它还可以让你在对象层的不同级别捕获事件。
通过event.stopPropagation()来阻止
$('#form1').submit(function(event){
event.preventDefault();
})
阻止冒泡和阻止默认行为合并起来写
// event.stopPropagation();
// event.preventDefault();
// 合并写法:
return false;
利用冒泡的原理,把事情加到父级上,通过判断事件来源的子集,执行相应的操作,事件委托首先可以极大减少事件绑定次数,提高性能;其次可以让新加入的子元素也可以拥有相同的元素。
一般绑定的写法
$(function(){
$ali = $('#list li');
$ali.click(function() {
$(this).css({background:'red'});
});
})
...
- 1
- 2
- 3
- 4
- 5
事件委托的写法
$(function(){
$list = $('#list');
$list.delegate('li', 'click', function() {
$(this).css({background:'red'});
});
})
...
- 1
- 2
- 3
- 4
- 5
var $div = $('');
var $div2 = $('这是一个div元素');
2>插入节点
append()和appendTo():在现存元素的内部,从后面插入元素
var $span = $('这是一个span元素');
$('#div1').append($span);
......
prepend()和prependTo():在现存元素的内部,从前面插入元素
after()和insertAfter():在现存元素的外部,从后面插入元素
before()和insertBefore():在现存元素的外部,从前面插入元素
3>删除节点
$('#div1').remove();
16)滚轮事件与函数节流
1>jquery.mousewheel插件使用
这个插件可以设置滚轮事件
2>函数节流
在短时间内多处触发执行绑定的函数,可以巧妙地使用定时器来减少触发的次数,实现函数的节流。
17)json
json,javascript对象表示法,目前比较流行,逐渐替换掉了传统的xml数据格式
{
"name":"tom",
"age":18
}
json数据格式的属性名称和字符串值需要用双引号引起来,用单引号或者不用引号会导致读取数据错误。
json的另外一个数据格式是数组。
[“tom”,18,“programmer”]
18)ajax与jsonp
ajax技术的目的是让JavaScript发送http请求,与后台通信,获取数据和信息。
原理:实例化xmlhttp对象,使用此对象与后台通信。
ajax通信的过程不会影响后续JavaScript的执行,从而实现异步。
1>同步异步
程序中的同步是做完一件事再做一件事,程序中的异步是同时做几件事。
2>局部刷新和无刷新
ajax可以实现局部刷新,也叫做无刷新。
定义:整个页面不刷新,只是局部刷新,ajax可以自己发送http请求,不用通过浏览器的地址栏,所以页面整体不会刷新,ajax获取到后台数据,更新页面显示数据的部分,就做到了页面局部刷新。
3>同源策略
ajax请求的页面或资源只能是同一个域下面的资源,不能是其他域的资源,这是在设计ajax时基于安全的考虑。
4>ajax使用方法
参数:
url 请求地址
type 请求方式,默认是’GET’,常用的还有’POST’
dataType 设置返回的数据格式,常用的是’json’格式,也可以设置为’html’
data 设置发送给服务器的数据
success 设置请求成功后的回调函数
error 设置请求失败后的回调函数
async 设置是否异步,默认值是’true’,表示异步
5>jsonp
ajax只能请求同一个域下的数据或资源。jsonp可以跨域请求数据。
原理:利用了
19)本地存储
本地存储分为cookie、以及新增的localStorage和sessionStorage
1>cookie存储在本地,容量最大4k,在同源的http请求时携带传递,损耗带宽,可设置访问路径,只有此路径及此路径的子路径才能访问此cookie,在设置的过期时间之前有效。
jquery 设置cookie
$.cookie('mycookie','123',{expires:7,path:'/'});
jquery 获取cookie
$.cookie('mycookie');
2>laocalStorage存储在本地,容量为5m或者更大,不会在请求时候携带传递,在所有同源窗口中共享,数据一直有效,除非人为删除,可作为长期数据。
//设置:
localStorage.setItem("dat", "456");
localStorage.dat = '456';
//获取:
localStorage.getItem("dat");
localStorage.dat
//删除
localStorage.removeItem("dat");
3>sessionStorage存储在本地,容量为5m或者更大,不会在请求时候携带传递,在同源的当前窗口关闭前有效。
localStorage 和 sessionStorage 合称为Web Storage , Web Storage支持事件通知机制,可以将数据更新的通知监听者,Web Storage的api接口使用更方便。
iPhone的无痕浏览不支持Web Storage,只能用cookie。
20)jqueryUI
以JQuery为基础的代码库。包含底层用户交互、动画、特效和可更换主题的可视控件。
3.移动端库和框架
1)移动端js事件
touch事件:
touchstart: //手指放到屏幕上时触发
touchmove: //手指在屏幕上滑动式触发
touchend: //手指离开屏幕时触发
touchcancel: //系统取消touch事件的时候触发,比较少用
移动端一般有三种操作,点击、滑动、拖动,这三种操作一般是组合使用上面的几个事件来完成的,所有上面的4个事件一般很少单独使用,一般是封装使用来实现这三种操作,可以使用封装成熟的js库。
2)zeptojs
zepto是一个轻量级的只针对现代高级浏览器的JavaScript库,它与jquery有着类似的api。
最初的目的是在移动端提供一个精简的类似jquery的js库。
3)swiper
一款成熟稳定的应用于pc端和移动端的滑动效果插件,一般用来触屏焦点图、触屏整屏滚动等效果。
参数:
initialSlide:初始索引值,从0开始
direction:滑动方向 horizontal | vertical
speed:滑动速度,单位ms
autoplay:设置自动播放及播放时间
autoplayDisableOnInteraction:用户操作swipe后是否还自动播放,默认是true,不再自动播放
pagination:分页圆点
paginationClickable:分页圆点是否点击
prevButton:上一页箭头
nextButton:下一页箭头
loop:是否首尾衔接
4)bootstrap
前端开发框架。
1>bootstrap容器
container-fluid流体
container 1170/970/750/100%
2>bootstrap响应式查询区间:
大于等于768
大于等于992
大于等于1200
3>bootstrap栅格系统
bootstrap将页面横向分为12等分,按照12等分定义了适应不同宽度等分的样式类,这些样式类组成了一套响应式、移动设备优先的流式栅格系统:
col-lg- 大于1200排成一行,小于1200分别占一行
col-md- 大于992排成一行,小于992分别占一行
col-sm- 大于768排成一行,小于768分别占一行
col-xs- 始终排列成一行