Python开发学习笔记(15)———— javascript 和 jQuery

1.javascript

1)介绍

主要解决的是前端与用户交互的问题,包括使用交互与数据交互。javascript是浏览器解释执行的,前端脚本还有Jscript(微软、IE独有),ActionScript(Adobe公司,需要插件)等。
前端三大块:
HTML:页面结构
CSS:页面表现;元素大小、颜色、位置、隐藏或显示、部分动画效果

2)JavaScript嵌入页面的方式
1>行间事件(主要用于事件)
<input type="button" name="" onclick="alert('ok!');">
2>页面script标签嵌入
<script type="text/javascript">        
    alert('ok!');
</script>
3>外部引入
<script type="text/javascript" src="js/index.js"></script>
3)变量

JavaScript的变量类型由它的值来决定。定义变量需要用关键字‘var’

var iNum = 123;
var sTr = ‘abc’;

变量类型
基本数据类型:
number数字类型;string字符串类型;boolean布尔类型true或false;undefined undefined类型、变量声明未初始化,它的值就是undefined;null null类型,表示空对象,如果定义的变量将来准备保存对象,可以将变量初始化为null,在页面上获取不到对象,返回的值就是null。
复合类型:
object
JavaScript中,一条语句用“;”结尾。

//为单行注释;/* kdf */为多行注释

命名规范:区分大小写;第一个字符必须是字母、下划线(_)或者美元符号($);其他字符可以是字母、下划线、美元符或数字

4)获取元素方法一

内置对象document上的getElementByld方法来获取页面上设置了id属性的元素,获取到的是一个html对象,然后将它赋值给一个变量。
JavaScript语句如果写在元素的上面,就会出错,因为页面是从上向下执行的。
解决方法:
1>将JavaScript放到页面最下边
2>将JavaScript语句放到Windows.onload触发的函数里面,获取元素的语句会在页面加载完后才执行,就不会出错了。

<script type="text/javascript">
    window.onload = function(){
        var oDiv = document.getElementById('div1');
    }
</script>
5)操作元素属性

操作元素的方法:
1> “.”操作 2> “[ ]”操作
属性写法:
1>html的属性和js里面属性写法一样
2>“class”属性协程“className”
3>“style”属性里面的属性,有横杆的改成驼峰式,比如:“font-size”,改成“style.fontSize”
innerHTML
innerHTML可以读取或者写入标签包裹的内容

6)函数

重复执行的代码片。

1>函数定义与执行
<script type="text/javascript">
    // 函数定义
    function fnAlert(){
        alert('hello!');
    }
    // 函数执行
    fnAlert();
</script>
2>变量与函数解析

JavaScript解析分为两个阶段,先是编译阶段,然后执行阶段。在编译阶段会将function定义的函数提前,并且将var定义的变量声明提前,将它赋值为undefined

3>提取行间事件

在html行间调用的事件可以提取到JavaScript中调用,从而做到结构与行为分离。

4>匿名函数

定义的函数可以不给名称,这个叫做匿名函数,可以将匿名函数直接赋值给元素绑定的事件来完成匿名函数的调用。

5>函数‘return’关键字

函数中‘return’关键字的作用:
a 返回函数执行的结果
b 结束函数的运行
c 阻止默认行为

7)条件语句

运算符
1>算术:+、-、*、/
2>赋值:=、+=、-=、*=、/=、%、
3>条件:==、===、>、>=、<、<=、!=、&&、||、!
== 有类型转换 2(整数)和‘2’(字符串),会出现相等的结果
=== 没有类型转换

if else
if(iNum01>iNum02){
    sTr = '大于';
}
else
{
    sTr = '小于';
}
switch语句
switch (iNow){
    case 1:
        ...;
        break;
    case 2:
        ...;
        break;    
    default:
        ...;
}
8)数组及操作方法

数组就是一组数据的集合,JavaScript中,数组里面的数据可以是不同类型的。

1>定义数组

var 数组名 = new Array(数据1,数据2,…)
var 数组名 = [数据1,数据2,…]

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

3>多维数组

数组中定义数组即可

9)循环语句
1>for循环
for(var i=0;i<len;i++)
{
}
2>while循环
while(条件){
…
i++;
}
3>数组去重

定义一个空数组,写一个双循环,使用indexOf()函数,判断是否和当前下标相等,如果相等,就加入到空数组中。

10)获取元素方法二

可以使用内置对象document上的getElementsByTagName方法来获取页面上的某一种标签,获取的是一个选择集,不是数组,但是可以用下标的方式操作选择集里的元素。

11)javascript组成

1>ECMAscript javascrip的语法(变量、函数、循环语句等语法)
2>DOM文档对象模型 操作html和css的方法
3>BOM浏览器对象模型 操作浏览器的一些方法

12)字符串处理方法

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合并为字符串。

13)类型转换

1>直接转换parselnt()与parseFloat()
2>隐式转换“==”和“-” 这两个字符会自动进行类型转换
3>NaN和isNaN

14)调试程序的方法

1>alert
2>console.log
3>document.title

15)定时器

1>定时器在javascript中的作用
制作动画;异步操作;函数缓冲与节流
2>定时器类型及语法
setTimeout 只执行一次的定时器
clearTimeout 关闭只执行一次的定时器
setInterval 反复执行的定时器
clearInterval 关闭反复执行的定时器
var time1 = setTimeout(myalert,2000);
第一个参数是执行的函数,第二个是时间,单位为毫秒

16)变量作用域

变量的作用范围,javascript中的变量分为全局变量和局部变量。
全局变量:在函数之外定义的变量,为整个页面公用,函数内部外部都可以访问。
局部变量:在函数内部定义的变量,只能在定义该变量的函数内部访问,外部无法访问。

17)封闭函数

javascript中匿名函数的另外一种写法,创建一个一开始就执行而不用命名的函数。

(function myalert(){
    alert('hello!');
})();

匿名函数的好处:可以创造一个独立的空间,在封闭函数内定义的变量和函数不会影响外部同名的函数和变量,可以避免命名冲突,在页面上引入多个js文件时,用这种方式添加js文件比较安全。

18)常用内置对象
1>document

document.getElementById //通过id获取元素
document.getElementsByTagName //通过标签名获取元素
document.referrer //获取上一个跳转页面的地址(需要服务器环境)

2>location

window.location.href //获取或者重定url地址
window.location.search //获取地址参数部分
window.location.hash //获取页面锚点或者叫哈希值

3>math

Math.random 获取0-1的随机数
Math.floor 向下取整
Math.ceil 向上取整

2. JQuery

1)介绍

jquery是一个函数库,一个js文件,页面用script标签引入这个js文件就可以使用。

2)jquery加载

将获取元素的语句写到页面头部,会因为元素还没有加载而出错,jquery提供了ready方法解决这个问题,它的速度比原生的 window.onload 更快。

<script type="text/javascript">

    $(function(){
    
         ......
    
    });

</script>
3)jquery选择器

jquery用法思想一:选择某个网页元素,然后对它进行某种操作

1>jquery选择器

可以快速地选择元素,选择规则和css样式相同,使用length属性判断是否选择成功

$('li') //选择所有的li元素
$('#ul1 li span') //选择id为为ul1元素下的所有li下的span元素
2>对选择集进行过滤
$('div').has('p'); // 选择包含p元素的div元素
$('div').not('.myClass'); //选择class不等于myClass的div元素
$('div').filter('.myClass'); //选择class等于myClass的div元素
$('div').eq(5); //选择第6个div元素
3>选择集转移
$('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的元素
4>判断是否选择成功

length为0就是没有选择到元素,大于0就是选择到了元素。

4)jquery样式操作

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样式
5)绑定click事件
1>给元素绑定click事件
$('#btn1').click(function(){

    // 内部的this指的是原生对象

    // 使用jquery对象用 $(this)

})
2>获取元素的索引值
var $li = $('.list li').eq(1);
alert($li.index()); // 弹出1
......
<ul class="list">
    <li>1</li>
    <li>2</li>
    <li>4</li>
    <li>5</li>
    <li>6</li>
</ul>
6)jquery特殊效果

fadeIn() 淡入

  $btn.click(function(){

        $('#div1').fadeIn(1000,'swing',function(){
            alert('done!');
        });
	1000为时间,单位为毫秒;‘swing’为缓冲运动

});

fadeOut() 淡出
fadeToggle() 切换淡入淡出
hide() 隐藏元素
show() 显示元素
toggle() 切换元素的可见状态
slideDown() 向下展开
slideUp() 向上卷起
slideToggle() 依次展开或卷起某个元素

7)jquery链式调用

jquery对象的方法会在执行完后返回这个jquery对象,所有jquery对象的方法可以连起来写:

$('#div1') // id为div1的元素
.children('ul') //该元素下面的ul子元素
.slideDown('fast') //高度从零变到实际高度来显示ul元素
.parent()  //跳到ul的父元素,也就是id为div1的元素
.siblings()  //跳到div1元素平级的所有兄弟元素
.children('ul') //这些兄弟元素中的ul子元素
.slideUp('fast');  //高度实际高度变换到零来隐藏ul元素
8)jquery动画

通过animate方法可以设置元素某属性值上的动画,可以设置一个或多个属性值,动画执行完成后会执行一个函数。

$('#div1').animate({
    width:300,
    height:300
},1000,'swing',function(){
    alert('done!');
});
9)尺寸相关、滚动事件
1>获取和设置元素的尺寸

width()、height() 获取元素width和height
innerWidth()、innerHeight() 包括padding的width和height
outerWidth()、outerHeight() 包括padding和border的width和height
outerWidth(true)、outerHeight(true) 包括padding和border以及margin的width和height

2>获取元素相对页面的绝对位置

offset()

3>获取浏览器可视区宽度高度
$(window).width();
$(window).height();
4>获取页面文档的宽度高度
$(document).width();
$(document).height();
5>获取页面滚动距离
$(document).scrollTop();  
$(document).scrollLeft();
6>页面滚动事件
$(window).scroll(function(){  
    ......  
})
10)jquery属性操作

1>html()取出或设置html内容

// 取出html内容

var $htm = $('#div1').html();

// 设置html内容

$('#div1').html('<span>添加文字</span>');

2>prop()取出或设置某个属性的值

// 取出图片的地址

var $src = $('#img1').prop('src');

// 设置图片的地址和alt属性

$('#img1').prop({src: "test.jpg", alt: "Test Image" });
11)jquery循环

对jquery选择的对象集合分别进行操作,需要用到jquery循环操作,此时可以用对象上的each方法

$(function(){
    $('.list li').each(function(i){
        $(this).html(i);
    })
})
12)jquery事件
1>事件函数列表

blur() 元素失去焦点
focus() 元素获得焦点
click() 鼠标单击
mouseover() 鼠标进入(进入子元素也触发)
mouseout() 鼠标离开(离开子元素也触发)
mouseenter() 鼠标进入(进入子元素不触发)
mouseleave() 鼠标离开(离开子元素不触发)
hover() 同时为mouseenter和mouseleave事件指定处理函数
ready() DOM加载完成
resize() 浏览器窗口的大小发生改变
scroll() 滚动条的位置发生变化
submit() 用户递交表单

2>绑定事件的其他方式
$(function(){
    $('#div1').bind('mouseover click', function(event) {
        alert($(this).html());
    });
});
3>取消绑定事件
$(function(){
    $('#div1').bind('mouseover click', function(event) {
        alert($(this).html());

        // $(this).unbind();
        $(this).unbind('mouseover');

    });

});
13)事件冒泡

在一个对象上触发某类事件(如单击),如果此对象定义了此事件的处理程序,那么此事件就会调用这个处理程序,如果没有定义此事件处理程序或者事件返回true,那么这个事件会向这个对象的父级对象传播,从里到外,直至它被处理(父级对象所有同类事件都将被激活),或者它到达了对象层次的最顶层,即document对象。

1>作用

事件冒泡允许多个操作被集中处理(把事件处理器添加到一个父类元素上,避免把事件处理器添加到多个子级元素上),它还可以让你在对象层的不同级别捕获事件。

2>阻止事件冒泡

通过event.stopPropagation()来阻止

3>阻止默认行为
$('#form1').submit(function(event){
    event.preventDefault();
})
4>合并阻止操作

阻止冒泡和阻止默认行为合并起来写

// event.stopPropagation();
// event.preventDefault();

// 合并写法:
return false;
14)事件委托

利用冒泡的原理,把事情加到父级上,通过判断事件来源的子集,执行相应的操作,事件委托首先可以极大减少事件绑定次数,提高性能;其次可以让新加入的子元素也可以拥有相同的元素。
一般绑定的写法

$(function(){
    $ali = $('#list li');
    $ali.click(function() {
        $(this).css({background:'red'});
    });
})
...
<ul id="list">
    <li>1</li>
    <li>2</li>
    <li>3</li>
    <li>4</li>
    <li>5</li>
</ul>

事件委托的写法

$(function(){
    $list = $('#list');
    $list.delegate('li', 'click', function() {
        $(this).css({background:'red'});
    });
})
...
<ul id="list">
    <li>1</li>
    <li>2</li>
    <li>3</li>
    <li>4</li>
    <li>5</li>
</ul>
15)jquery元素节点操作
1>创建节点
var $div = $('<div>');
var $div2 = $('<div>这是一个div元素</div>');
2>插入节点

append()和appendTo():在现存元素的内部,从后面插入元素

var $span = $('<span>这是一个span元素</span>');
$('#div1').append($span);
......
<div id="div1"></div>

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- 始终排列成一行

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值