转自:CSDN--http://blog.csdn.net/cherry_vicent/article/details/42120149

1、javascript是什么

 

根据用户的一些操作,然后来修改页面上的一些元素、属性等。

(1)HTML+CSS静态页面,JS给页面添加动的效果

(2)网页特效的原理

javascript就是修改样式

(3)编写JS的流程:

【1】布局:HTML+CSS

【2】属性:确定要修改哪些属性

【3】事件:确定用户做哪些操作

【4】编写JS:在事件中,用JS来修改页面元素的样式

补:事件:就是用户操作,如鼠标点击、移入、移出等

(4)id:在css中,id作为css里的一个选择符存在,而在JS里它有更加广泛的用途,

在JS中扮演标签(元素)名字的作用,如<div id="div1">......</div>,id在这个例子里扮演了div名字的作用,div1就是div的名字

(5)div1.style.display='block'

点 .      ------> 的,一般来说是所属的关系,其实是属性

等号 = ------> 在数学里,x=5,表示x的值就是5,即等号就是相等的意思

在JS里,等号并不是相等的意思,等号指赋值,把什么变成什么,把=右边的值赋给左边

2、第一个JS兼容性问题:document.getElementById

 

(1)在FF和低版本的chrome下,是不能直接拿着id就用的,存在兼容问题

真正兼容的写法是document.getElementById('id名字'),在任何浏览器下均可用

如:document.getElementById('div1');

通过div1这个id把元素获取出来,然后再来用

注:记住,不能直接拿着id就用,而必须的通过getElementById(把元素获取出来)获取一下,然后才可以用

(2)网页换肤

(1) 任何标签都可以加ID,包括link

(2) 任何标签的任何属性,也都可以修改

(3) HTML里怎么写,JS里就怎么写,只有一个例外就是class,因为class在JS里是关键字(保留字),所以不能直接拿来用,要写成className

3、引入函数:因为直接在事件内写代码会很乱

(1)函数基本格式:

  1. function 函数名()
  2. {
  3. 代码
  4. }

JS里的函数和css里的class有点相似,像class它最大的一个功能就是你把这个样式写到class里边,然后只要需要这套样式的地方,直接把那个class拿过去用就

可以了,同样JS里的函数也一样.

(2)函数的定义和调用

  1. function show()        //定义
  2. {
  3. alert('abc');
  4. }
  5. show();               //调用

函数定义:只是告诉系统有这个函数,不会实际执行

函数调用:真正执行函数里的代码

注:函数的定义和调用缺一不可,只有定义则没反应,只有调用则显示出错了

(3)引入变量的概念:考虑到重用

变量:就是给东西取了个别名

如var oDiv=document.getElementById('div1');给后面这大串取了个别名叫oDiv。看到oDiv就跟看到document.getElementById('div1')是一样的效果

注:(1) 如果你要操作一个元素,你必须先把它选择过来,比如现在要操作的是text这个元素,那么需要先给它加个id,比如id="txt1",然后function函数里用

getElementById把它给选择过来

(2) 要操作谁,就要获取谁

(3) 需要一个函数,这个函数是为按钮准备的,因为它点击需要一个函数

4、if判断:如点击按钮显示/隐藏div(弹出菜单)

(1)if判断基本格式:

  1. if(条件)
  2. {
  3. 语句1
  4. }
  5. else
  6. {
  7. 语句2
  8. }

翻译:如果条件成立就执行语句1,如果条件不成立就执行语句2

 注:(1) if :如果

(2) 条件:在IS里是判断的意思,就是遇到不同的情况就做不同的操作,遇到不同的问题就做不同的处理

(2)单等和双等(=和==)

=    赋值(改变,变成)

==   判断(判断两边是否相等)

(3)为a链接添加JS

<!--<a href="javascript:alert('a');">链接</a> -->

<a href="javascript:;">链接</a>

一般a里不加JS代码,而是空的js原因:(1) 在a里加js代码不好 (2) 加空的js代码而不是加#,因为它不会像#那样一点就跳到页首。

初探Javascript魅力(1)的更多相关文章

  1. 【JavaScript从入门到精通】第四课初探JavaScript魅力-04

    第四课初探JavaScript魅力-04 style与className 之前我们已经讲过,style用于在JS里控制元素的样式,通过style可以选中元素的各种css属性.此外,我们也提到过,JS用 ...

  2. 【JavaScript从入门到精通】第三课 初探JavaScript魅力-03

    第三课 初探JavaScript魅力-03 函数传参 上节课的时候我们已经讲了什么是函数,实际上,函数在功能上就类似于css的class一样,将一段代码包裹起来使用.为了让函数的功能更加的丰富和实用, ...

  3. 【JavaScript从入门到精通】第二课 初探JavaScript魅力-02

    第二课 初探JavaScript魅力-02 变量 说起变量,我们不得不提起我们有一部比较古老的电视剧叫<包青天>.包青天有一把非常厉害的宝剑叫“尚方宝剑”,见到尚方宝剑有如见到皇帝.某种程 ...

  4. 【JavaScript从入门到精通】第一课 初探JavaScript魅力-01

    第一课 初探JavaScript魅力-01 JavaScript是什么 如今我们打开一个大型的网站,都会有很多JS效果的功能和应用.对于学过CSS+HTML的同学,即使是像淘宝那样的网站,用一两天时间 ...

  5. 01 - 初探JavaScript魅力

    网页特效原理 用JavaScript修改样式 编写JS的流程 布局:HTML+CSS 属性:确定要修改哪些属性 事件:确定用户做哪些操作(产品设计) 编写JS:在事件中,用JS来修改页面元素的样式 鼠 ...

  6. 初探JavaScript魅力(二)

    行为,样式,结构三者分离(javascript, css, html),不要在行间加行为,样式 样式优先级:*<标签<class<ID<行间 style与className,如 ...

  7. 初探JavaScript魅力(五)

    JS简易日历    innerHTML <title>无标题文档</title> <script> var neirong=['一','二','三','四','五' ...

  8. 初探JavaScript魅力(四)

    选项卡 <title>无标题文档</title> <style> #div1 .active{background:#FF0;} #div1 div{width:2 ...

  9. 初探JavaScript魅力(三)

    复选框的全选.反选和不选 <title>无标题文档</title> <style> body{background:#666;} </style> &l ...

随机推荐

  1. Synchronized 与 ReentrantLock 的区别!

    来源:cnblogs.com/baizhanshi/p/7211802.html 之前栈长分享了重入锁的概念:<到底什么是重入锁,拜托,一次搞清楚!>,今天现来深入了解下 Synchron ...

  2. CentOS MySQL 5.7编译安装

    CentOS MySQL 5.7编译安装 MySQL 5.7 GA版本的发布,也就是说从现在开始5.7已经可以在生产环境中使用,有任何问题官方都将立刻修复. MySQL 5.7主要特性: 更好的性能: ...

  3. pytest框架结构运行规则及命名方式

    Pytest框架结构 Import pytest 类似的setup,teardown同样更灵活,还有个session() 模块级 (setup_module/teardown_module) 不在类中 ...

  4. linux 下新建文件自动加锁的解决办法

    导致文件夹里面无法保存别的文件 sudo chmod 777 -R 文件或目录

  5. Gym 102007I 二分 网络流

    题意:给你一张图,每个城市有一些人,有不超过10个城市有避难所,避难所有容量上限,问最快多久可以让所有人进入避难所? 思路:二分时间,对于每个时间跑一遍最大流,判断最大流是不是人数即可.我们还需要用二 ...

  6. winpe

    winpe winpe winpe 工具 判断是否pe系统的方法:GetSystemDisk()

  7. 【Luogu】【关卡1-8】BOSS战-入门综合练习2(2017年10月)【AK】------都是基础题

    P1426 小鱼会有危险吗 我个人觉得这个题目出的不好,没说明白,就先只粘贴的AC代码吧 #include <bits/stdc++.h> using namespace std; int ...

  8. 8、Python MySQL - mysql-connector 驱动

    一. 在线安装 mysql-connector :  pip install mysql-connector-python 二.操作流程 1.连接数据库信息: conn =  mysql.connec ...

  9. codeforces 1A

    题目大意: 就是在一块长方形地面上铺瓷砖,然后一共要用多少块瓷砖,一块瓷砖被割开后只能用一次,输入长,宽,以及瓷砖边长,求一共需要多少块瓷砖: 基本思路: 这里有个技巧:就长来说,需要(n+k-1)/ ...

  10. 【错误总结】Component template should contain exactly one root element. If you are using v-if on multiple elements, use v-else-if to chain them instead.

    大致意思是因为模板里面应该包含一个根元素,使用组件的时候应该用div或p标签包起来