一、函数变量的作用域

1.变量的作用域实在声明时决定的而不是调用执行时决定

<script>
var a=6,b=7;
function t() {
// var a=3,b=5;
console.log(a+'--'+b);
}
t();
</script>

2.作用域

<script>
var a=8,b=9;
function sum() {
// var a=3,b=5;
function p() {
// var a=4,b=6;
console.log(a+b);
}
p();
}
sum();
</script>

二、词法分析

1.函数执行前,会进行预编译,这个预编译的过程就是词法分析
会形成一个活动对象,Active Object AO
分析三个内容:
1.分析函数的参数
2.分析函数的变量声明
3.分析函数内函数声明表达式

var str ='global';
function t() {
console.log(str); // unfined
var str = 'local';
console.log(str); // local
}
t();
-----------------------------------------------------
<script>
function t(age) {
console.log(age);
var age = 99;
console.log(age);
function age(){
}
console.log(age)
}
t(5);
//预编译,activeobject AO
/*
* 1.分析函数参数
* AO.age = undefined
* 1.2 AO.age = 5
* 2.分析函数变量
* 因为AO有age变量,所以不做任何处理(没有的话就赋值)
* 3.函数声明表达式
* AO.age = function age(){}
* */
</script>

三、jQuery

DOM:

1.直接查找
  document.getElementById 根据ID获取一个标签
  document.getElementsByName 根据name属性获取标签集合
  document.getElementsByClassName 根据class属性获取标签集合
  document.getElementsByTagName 根据标签名获取标签集合
2.间接查找
  parentNode // 父节点
  childNodes // 所有子节点
  firstChild // 第一个子节点
  lastChild // 最后一个子节点
  nextSibling // 下一个兄弟节点
  previousSibling // 上一个兄弟节点

  parentElement // 父节点标签元素
  children // 所有子标签
  firstElementChild // 第一个子标签元素
  lastElementChild // 最后一个子标签元素
  nextElementtSibling // 下一个兄弟标签元素
  previousElementSibling // 上一个兄弟标签元素

1.jQuery是什么

  jQuery:帮我们封装好了DOM操作,相当于python中的模块(类库)

2.jQuery的特点

  1.强大的选择器---类似与css的选择器
  2.强大的DOM操作
  3.Ajax封装
  4.版本兼容行好

3.jQuery版本:

  1.xxx --- 1.12.4(1.12大版本)
  2.xxx
  3.xxx

4.选择器

------基本选择器
ps:
  jQuery --> DOM
    $("#test")[0]
  DOM --> jQuery
    var mydom = document.getElementById('test')
    $(mydom)
1.ID选择器
  $('#test') == document.getElementById('test')
2.标签选择器
  $('div') == document.getElementsByTagName('div')
3.class选择器
  $('.class') == document.getElementsByClassName("class")
4.组合选择器
  $('div,span')

------层级选择器
1.祖先--子孙 *有疑问(括号中是否可以是上面选择器中的任意)
$('form input')
2.parent > childNodes 只找儿子
$(' form > input')

------基本筛选器
:first 获取匹配的第一个元素
$('li:first') 获取li标签的第一个元素
:last 获取匹配的最后一个元素
$('li:last') 获取li标签的最后一个元素
:eq(n) 获取匹配的第n个元素
$('li:eq(3)') 获取li标签的第4个元素

------属性选择器
<input type="text" name="username"/>
$('input[type="text"]')

5.jQuery的方法
1.$(this) 相当于js中的this
2.each 相当于循环操作
3.prop 给标签设置属性,例 $(this).prop('checked',true)
给一个参数为获取值,两个值为设置值

4.三元运算

  例: 4 > 3 ? true : false

5.筛选器

  1.next() 获取紧邻的下一个元素
    nextAll()
    nextUtil('.content1') 直到XXX停止
  2.prev() 获取紧邻的上一个元素
    prevAll()
    prevUtil('.content1') 直到XXX停止
  3.children() 获取所有的子元素
    $('.info').children() ---获取所有的子元素
    $('.info').children('.content2') ---获取指定的子元素
  4.parent() 获取父元素
    $('content2').parent()
  5.siblings() 获取兄弟元素
    $('content2').parent().children('.content2').siblings()

5.设置样式

  css() 传一个参数为获取值,传两个值为设置值
  css('display')
  css('display','block')

6.动画  

  1.$('img').show(1000) 显示隐藏的 1000为慢慢显示
  2.$('img').hide(1000) 隐藏显示的 1000为慢慢隐藏
  3.$('img').toggle('slow') 显示隐藏,隐藏显示。slow变慢
  更多:http://jquery.cuishifeng.cn/

7.样式

  1.$("XXX").css("display",none) 设定样式
  2.addClass() 添加样式(要求样式存在,即写在css里面)
  3.removeClass() 移除样式(同上)
  4.hasclass() 判断有没有样式

8.文本操作

  1.设置text的值
    $('xxx').text() 不传参为获取
    $('xxx').text('helei') 传参为设置
  2.input系列框里边的值(同上)
    $('xxx').val()
    $('xxx').val('helei')

9.属性操作

    $('xxx').attr(""); 属性选择器,传一个参数为取值
    $('xxx').attr("",""); 属性选择器,传两个值为赋值
    $('xxx').removeAttr('key') 输入属性的key,可以删除属性

    在操作关于input系列(radio,checkbox) 选中和取消不能采用attr来进行设置
    3版本修复了这个bug
    prop()专门是用来对input系列(radio,checkbox)
      $('xxx').prop()

10.文档操作

  append() 向选中的元素内部的后面添加元素
    $("ul").append($("<li>某某某</li>"))
  appendTo() 把元素插到某个元素的后面
    $("<li>某某某</li>").appendTo($("ul"))

  prepend() 向选中的元素内部的前面添加元素
  prependTO() 把元素插到某个元素的前面

  外部插入
    after() 向选中元素外部的后面添加元素
    before() 向选中元素外部的前面添加元素

  删除
    empty() 将元素内部的内容删除
    remove() 将元素的标签删除

11.表单对象属性

  :enabled 匹配所有可用元素
  :disabled 匹配所有不可用元素
    <form>
      <input name="email" disabled="disabled" />
      <input name="id" />
    </form>
  $("input:disabled")
  [ <input name="email" disabled="disabled" /> ]
  :checked 匹配所有选中的被选中元素(复选框、单选框等,select中的option),对于select元素来说,获取选中推荐使用 :selected
  :select 匹配所有选中的option元素

12.事件

  DOM:
    onclick
    onblur
    onfocus
    ondblclick
    onmousedown
    onmouseover
    onkeydown
    onkeyup

  jquery:
    click
    blur
    focus
    dblclick
    mousedown
    mouseover
    keydown
    keyup

13.绑定事件的其他方式

  $('xxx').on("click",function(){})
  $('xxx').off("click",function(){})

  $('xxx').bind("click",function(){})
  $('xxx').unbind("click",function(){})

  $('xxx').delegate('xxx','click',function(){})
  $('xxx').undelegate('xxx','click',function(){})

14.阻止事件发生:

  return false

jQuery简介和基础的更多相关文章

  1. jQuery编程基础精华01(jQuery简介,顶级对象$,jQuery对象、Dom对象,链式编程,选择器)

    jQuery简介 什么是jQuery? jQuery就是一个JavaScript函数库,没什么特别的.(开源)联想SQLHelper类 jQuery能做什么?jQuery是做什么的? jQuery本身 ...

  2. jQuery 简介

    jQuery 简介 jQuery 库可以通过一行简单的标记被添加到网页中. jQuery 库 - 特性 jQuery 是一个 JavaScript 函数库. jQuery 库包含以下特性: HTML ...

  3. jQuery Mobile 入门基础教程

    jQuery Mobile是jQuery在手机上和平板设备上的版本.jQuery Mobile 不仅会给主流移动平台带来jQuery核心库,而且会发布一个完整统一的jQuery移动UI框架. jQue ...

  4. WEB入门之十二 jquery简介

    学习内容 jQuery简介 搭建jQuery开发环境 jQuery基本选择器 能力目标 熟悉jQuery开发环境 能编写简单的jQuery代码 本章简介 在前面两章,我们学习了JavaScript面向 ...

  5. jQuery和AJAX基础

    jQuery和AJAX基础 jQuery 基础: 1.jQuery 选择器: 元素选择器:$("p"): #id 选择器:$("#test"): .class ...

  6. APP接口自动化测试JAVA+TestNG(二)之TestNG简介与基础实例

    前言 继上篇环境篇后,本篇主要对TestNG进行介绍,给出最最基础的两个实例,通过本文后,学会并掌握TestNG测试用例的编写与运行,以及生成美化后的报告.下一篇为HTTP接口实战(国家气象局接口自动 ...

  7. jQuery简介

    jQuery简介 jQuery是继Prototype之后的又一个javascript库,它由John Resig创建于2006年1月. Javascript库作用比较: 1. Prototype(ht ...

  8. jQuery学习笔记 - 基础知识扫盲入门篇

    jQuery学习笔记 - 基础知识扫盲入门篇 2013-06-16 18:42 by 全新时代, 11 阅读, 0 评论, 收藏, 编辑 1.为什么要使用jQuery? 提供了强大的功能函数解决浏览器 ...

  9. jQuery简介<思维导图>

    jQuery是继prototype之后有一个优秀的Javascript库,它由John Resig创建于2006年1月.它简化了遍历HTML文档.操作DOM.处理事件.执行动画和Ajax的操作.它独特 ...

随机推荐

  1. 《高级软件测试》Windows平台Jira的配置

    昨天完成了Jira的下载,很开心地去睡觉等明天天亮秒配环境愉快进行使用,撰写文档,开始徜徉于软件管理测试实践,早日走向代码巅峰. 我们把安装和配置的过程来走一遍. 安装完成汤姆猫长这样子: 安装Jir ...

  2. bzoj千题计划275:bzoj4817: [Sdoi2017]树点涂色

    http://www.lydsy.com/JudgeOnline/problem.php?id=4817 lct+线段树+dfs序 操作1:access 操作2:u到根的-v到根的-lca到根的*2+ ...

  3. Network in Network

     论文要点: 用更有效的非线性函数逼近器(MLP,multilayer perceptron)代替 GLM 以增强局部模型的抽象能力.抽象能力指的模型中特征是对于同一概念的变体的不变形. 使用 gl ...

  4. nyoj 对决吃桃

    时间限制:3000 ms  |  内存限制:65535 KB 难度:0   描述 有一堆桃子不知数目,猴子第一天吃掉一半,又多吃了一个,第二天照此方法,吃掉剩下桃子的一半又多一个,天天如此,到第m天早 ...

  5. EasyUI datagrid 使用小结

    用了 EasyUI 框架一段时间了,这个前端框架用起来还是挺方便的,也有很多现成的控件,看看官方文档应该还是能比较快用起来的. 在这里记录一下一些常用的控件的方法,遇到过的bug或者当初耗了一点时间来 ...

  6. Python内置函数(41)——id

    英文文档: id(object) Return the "identity" of an object. This is an integer which is guarantee ...

  7. c++中模板是什么?为什么要定义模板?

    一.c++中模板是什么? 首先: int Max(int x, int y) { return x > y ? x : y; } float Max(float a,float b) { ret ...

  8. kubernetes入门(06)kubernetes的核心概念(3)

    一.API 对象 API对象是K8s集群中的管理操作单元.K8s集群系统每支持一项新功能,引入一项新技术,一定会新引入对应的API对象,支持对该功能的管理操作.例如副本集Replica Set对应的A ...

  9. [洛谷P1196][NOI2002]银河英雄传说 - 带偏移量的并查集(1)

    Description 公元五八〇一年,地球居民迁至金牛座α第二行星,在那里发表银河联邦创立宣言,同年改元为宇宙历元年,并开始向银河系深处拓展. 宇宙历七九九年,银河系的两大军事集团在巴米利恩星域爆发 ...

  10. hdu1050 Moving Tables---贪心

    题目链接: http://acm.hdu.edu.cn/showproblem.php?pid=1050 题目大意:就说有一些桌子需要从某些房间搬到另一些房间,但中间只有一条走廊,且走廊中任何一段只能 ...