一、昨日内容回顾

    1.绝对定位的盒子居中

      left:50%;

      margin-left:负的盒子宽度的一半

    2.固定位置

      脱离标准文档流

      作用:返回顶部,广告,滚动监听栏、固定导航栏(body{margin-top:100px或padding-top:100px;})。

二、今日内容总结

    1.javascript的介绍和作用

      DOM:Document Object Model

      BOM:Browe Object Modle

   2. js三大部分

      1)、ECMAScript基础语法

          javascript语法标准。包括变量、表达式、运算符、函数、if语句、for语句等 

          (1) 初识js

              <script type="text/javascript"> <script>

              alert('xxx')

              console.log('xxx')# 控制台输出

              console.dir("xxx")

              var a = prompt('xxx')

              单行注释// 多行注释/*  */

              语法规则:JavaScript对换行、缩进、空格不敏感,语句末尾加分号,单行注释// 多行注释/*  */

          (2)直接量:数字99和字符串“99”

          (3) 变量:定义 赋值 命名规范

             a.变量的定义提升

             b.x = a++  和 x= ++a 的区别

          (4) 变量的类型(typeof  变量)

              number

              string

             undfined    # 布尔值为false

             null  # 布尔值为false

             NaN  number  # 布尔值为false

             infinity  无限大  # 布尔值为true

           连字符和加号

            (5)变量的转换

            parseInt()

                (1)带有自动净化的功能;只保留字符串最开头的数字,后面的中文自动消失。例如:

                 (2)自动带有截断小数的功能:取整,不四舍五入

            parseFloat()

            parseString()    

          (2) 基础数据类型

             # number

             # string

               # boolean

             # null

             # undefined

              引用数据类型:   

          • Function
          • Object
          • Arrray
          • String
          • Date

         (3)运算符 

                # 赋值运算符: = 、+=、-=、%=、*=、/=

             # 算数运算符: +、-、*、/、%、++、--

            #  比较运算符:==、===、!==、!===、>、<、>=、<=

         特殊情况:字符串拼接和es6模板字符串(·hh·)                

<!DOCTYPE html>
<html>
<head>
<title></title>
</head>
<body>
<script type="text/javascript">
//方法一:
var firstName = '小';
var lastName = '马哥';
var name = '伊拉克';
var am = '美军';
// 字符串拼接
var str = "2003年3月20日,"+name+"战争爆发,以美军为主的联合部队仅用20多天就击溃了萨达姆的军队。这是继十多年前的海湾战争后,"+am+"又一次取得的大规模压倒性军事胜利。"
var fullStr = str;
console.log(fullStr) var fullName = firstName +" "+ lastName;
console.log(fullName)
// 方法二:
var str = `2003年3月20日 ${name}战争爆发,以美军为主的联合部队仅用20多天就击溃了萨达姆的军队。这是继十多年前的海湾战争后,${am}又一次取得的大规模压倒性军事胜利。`
console.log(str)
</script> </body>
</html>

··

           (4) 数据类型转换

             # 数字转字符串

                a. 隐式转换 1+‘2’ 输出‘12‘

                b.强制转换 string() 、 tostring()

             # 字符串转数字

                 parseInt()、parseFloat()

               # 任何数据类型转成boolean()

           ( 5 ) 流程控制

              #  if(){} else{}

              #   if() {} else if() {} else{}

              #   while(){}

              #   do{} while()

              #   for(var i=0,i<10,i++){}

              # switch(变量) {

                     case ‘1’:

                       XXXX

                        break # 如果没有break 它就会一直执行,直至遇到下一个break 这个叫case穿透。

                     case ‘2’:

                       XXXX

                        break

                      。。。。

                      default:

                       console.log('很遗憾')

                  }

            (6) 常用内置对象

                #  数组Array

                #  字符串String

                #  Date

                #  math对象

               http://www.cnblogs.com/majj/p/9095590.html 

            (7) 函数

                # 定义:

                 function 函数名(参数){}

                # 函数的调用:

                  函数名()

                # 函数的返回值

            (8)为数组arguments            

<!DOCTYPE html>
<html>
<head>
<title></title>
</head>
<body>
<script type="text/javascript"> function add(a,b,c){
console.log(add.length) //形参个数
console.log(arguments.length) //实参个数
console.log(arguments) //实参
return a+b+c
}
add(1,2)
var z = add(1,2,3)
console.log(z)
</script>
</body>
</html>

伪数组

               之所以说arguments是伪数组,是因为:arguments可以修改元素,但不能改变数组的长短。举例:

                   清空数组的三种方式:

                
    var a1 = [1,2,3,4]
    // a1.splice(0)
    // a1 = []
    a1.length=0
    console.log(a1)

      2)、DOM

          操作网页上元素的API。比如盒子移动、变色、轮播图等

          1.事件源、事件、事件驱动程序

          2.获取文档元素节点、属性节点、文本节点

            # 获取文档元素节点、增加、删除等

              document  //文档

              document.documentElement //html

              document.body//body

                

              var oBtn = document.getElementById('')

              var oBtn = document.getElementsByTagName('')

              var oBtn = document.getElementsByClassName('')

            # 获取文档属性节点

             oBtn.src  oBtn.classname

               oBtn["src"]

<!DOCTYPE html>
<html>
<head>
<style>
div
{
width:100px;
height:100px;
background:red;
position:relative;
animation:mymove 5s infinite;
-webkit-animation:mymove 5s infinite; /*Safari and Chrome*/
} @keyframes mymove
{
from {left:0px;}
to {left:200px;}
} @-webkit-keyframes mymove /*Safari and Chrome*/
{
from {left:0px;}
to {left:200px;}
}
</style>
</head>
<body> <p><strong>注释:</strong>Internet Explorer 9 以及更早的版本不支持 animation 属性。</p> <div></div> </body>
</html>

移动效果关联

      3)、BOM

          操作浏览器部分功能的API。比如让浏览器自动滚动。

三、扩展和预习

   1 transition:属性 过渡时间 过渡函数效果 延迟时间

    

<!DOCTYPE html>
<html>
<head>
<title></title>
<style type="text/css">
.box1{
visibility: hidden;
width: 200px;
height: 200px;
background-color: #333;
transition: all 2s ease-in 0.2s;
}
.box2{
position: absolute;
width: 200px;
height: 200px;
background-color: red;
}
.box2:hover .box1{
visibility: visible;
width: 300px; }
</style>
</head>
<body> <div class="box2"><div class="box1"></div></div> </body>
</html>

矩形框变大的过程

     2. transform # div旋转

 

<!DOCTYPE html>
<html>
<head>
<style>
.box1
{
margin:30px;
width:200px;
height:100px;
background-color:yellow;
/* Rotate div */
transform:rotate(20deg);
-ms-transform:rotate(9deg); /* Internet Explorer */
-moz-transform:rotate(9deg); /* Firefox */
-webkit-transform:rotate(30deg); /* Safari 和 Chrome */
-o-transform:rotate(9deg); /* Opera */
}
</style>
</head>
<body> <div class="box1">Hello World</div>
<div style="height: 300px;background-color: red;"> </div> </body>
</html>

div旋转实例

      3.animation # 移动效果关联

<!DOCTYPE html>
<html>
<head>
<style>
div
{
width:100px;
height:100px;
background:red;
position:relative;
animation:mymove 5s infinite;
-webkit-animation:mymove 5s infinite; /*Safari and Chrome*/
} @keyframes mymove
{
from {left:0px;}
to {left:200px;}
} @-webkit-keyframes mymove /*Safari and Chrome*/
{
from {left:0px;}
to {left:200px;}
}
</style>
</head>
<body> <p><strong>注释:</strong>Internet Explorer 9 以及更早的版本不支持 animation 属性。</p> <div></div> </body>
</html>

移动效果关联

python全栈开发day43-javascript的更多相关文章

  1. Python全栈开发:Javascript

    JavaScript是一门编程语言,浏览器内置了JavaScript语言的解释器,所以在浏览器上按照JavaScript语言的规则编写相应代码之,浏览器可以解释并做出相应的处理. 一.如何编写 1.J ...

  2. python全栈开发目录

    python全栈开发目录 Linux系列 python基础 前端~HTML~CSS~JavaScript~JQuery~Vue web框架们~Django~Flask~Tornado 数据库们~MyS ...

  3. Python 全栈开发【第0篇】:目录

    Python 全栈开发[第0篇]:目录   第一阶段:Python 开发入门 Python 全栈开发[第一篇]:计算机原理&Linux系统入门 Python 全栈开发[第二篇]:Python基 ...

  4. Python全栈开发【面向对象进阶】

    Python全栈开发[面向对象进阶] 本节内容: isinstance(obj,cls)和issubclass(sub,super) 反射 __setattr__,__delattr__,__geta ...

  5. Python全栈开发【面向对象】

    Python全栈开发[面向对象] 本节内容: 三大编程范式 面向对象设计与面向对象编程 类和对象 静态属性.类方法.静态方法 类组合 继承 多态 封装 三大编程范式 三大编程范式: 1.面向过程编程 ...

  6. Python全栈开发【模块】

    Python全栈开发[模块] 本节内容: 模块介绍 time random os sys json & picle shelve XML hashlib ConfigParser loggin ...

  7. Python全栈开发【基础四】

    Python全栈开发[基础四] 本节内容: 匿名函数(lambda) 函数式编程(map,filter,reduce) 文件处理 迭代器 三元表达式 列表解析与生成器表达式 生成器 匿名函数 lamb ...

  8. Python全栈开发【基础三】

    Python全栈开发[基础三]  本节内容: 函数(全局与局部变量) 递归 内置函数 函数 一.定义和使用 函数最重要的是减少代码的重用性和增强代码可读性 def 函数名(参数): ... 函数体 . ...

  9. Python全栈开发【基础二】

    Python全栈开发[基础二] 本节内容: Python 运算符(算术运算.比较运算.赋值运算.逻辑运算.成员运算) 基本数据类型(数字.布尔值.字符串.列表.元组.字典) 其他(编码,range,f ...

  10. Python全栈开发【基础一】

    Python全栈开发[第一篇] 本节内容: Python 的种类 Python 的环境 Python 入门(解释器.编码.变量.input输入.if流程控制与缩进.while循环) if流程控制与wh ...

随机推荐

  1. 数据库的一致性读,赃读,多线程与赃读,ACID,UNDO

    赃读 对于对象额同步异步方法,我们在设计自己的程序的时候,一定要考虑的问题整体,不然会出现数据不一致的错误,很经典的就是赃读(dityread) 示例: ​ package com.nbkj.thre ...

  2. 20155117王震宇 2016-2017-2 《Java程序设计》第六周学习总结

    教材学习内容总结 IO流的分类: 根据流的数据对象来分: 高端流:所有的内存中的流都是高端流,比如:InputStreamReader 低端流:所有的外界设备中的流都是低端流,比如InputStrea ...

  3. nginx 全局配置

    nginx 全局配置 #user nobody; # user 主模块 ,指定nginx worker 进程的运行用户组 worker_processes ; # worker_processes 开 ...

  4. Netty入门(2) - 核心概念

    Netty Crash Course 一个Netty程序一般开始于Bootstrap类,通过设置程序后,使用Handlers来处理特定的event和设置Netty中的事件,从而处理多个协议数据,比如实 ...

  5. 如何利用 Python 完成验签操作

    柠檬班Python8期的佑佑以及Python7期的掠掠同学昨天都私下问华华老师如何利用Python完成验签的操作. 今天我们就以佑佑的例子来跟大家进行简单的说明以及操作! 一.什么是验签: 用非常简单 ...

  6. JQuery 的Bind()事件

    刚开始我们先看一下它的定义: .bind( eventType [, eventData], handler(eventObject)) .Bind()方法的主要功能是在向它绑定的对象上面提供一些事件 ...

  7. 2017/05/08 java 基础 随笔

    1.null pointer exception 指针变量obj 没有指向任何空间 你调用它的方法和属性就会出错 2.基本数据类型值传递,不改变原值,调用后就会弹栈,局部变量随时消失 引用数据类型值传 ...

  8. 【ARTS】01_10_左耳听风-20190114~20190120

    ARTS: Algrothm: leetcode算法题目 Review: 阅读并且点评一篇英文技术文章 Tip/Techni: 学习一个技术技巧 Share: 分享一篇有观点和思考的技术文章 Algo ...

  9. CentOS6.5运行yum报错:No module named yum

    公司测试机环境不知道给我卸了什么包,导致yum运行报错状况: 报错情况: There was a problem importing one of the Python modulesrequired ...

  10. 详解.NET IL代码(一)

    本文主要介绍IL代码,内容大部分来自网上,进行整理合并的. 一.IL简介 为什么要了解IL代码? 如果想学好.NET,IL是必须的基础,IL代码是.NET运行的基础,当我们对运行结果有异议的时候,可以 ...