首页 > 其他分享 >前端第四课---JS简介及其相关语法

前端第四课---JS简介及其相关语法

时间:2022-12-05 19:34:12浏览次数:38  
标签:第四课 username jason undefined 代码 JS --- var js

上周内容回顾

  • 边框属性

    border-上下左右-颜色、宽度、样式
    
    border-上下左右
    
    border
    
    border-raduis:50%
    
  • 盒子模型

    margin-上下左右
    
    margin
    
    padding-上下左右
    
    padding
    
  • display属性

    display:none\block
    
  • 浮动布局

    float:left\right
    
  • clear属性

    浮动会造成父标签塌陷的问题
    
    .clearfix:after {
        content:'';
        display:block;
        clear:both
    }
    
  • 定位操作

    静态定位	static
    相对定位	relative
    绝对定位	absolute
    固定定位	fixed
    
  • z-index属性

    模态框
    

body里面放的是浏览器展示给用户看的数据!!!

今日内容概要

主题:JavaScript编程语言

  • JS简介
  • 变量与常量
  • 基本数据类型
  • 运算符
  • 流程控制
  • 函数
  • 内置对象
  • BOM与DOM操作

今日内容详细

JS简介

全称JavaScript但是与Java一毛钱关系都没有 之所以这么叫是为了蹭Java的热度

它是一门前端工程师的编程语言 但是它本身有很多逻辑错误(不是很严谨)

IT行业鄙视链: 后端 > 前端、运维、测试、产品、老板
前端想一统天下:node.js

JS发展史>>>:JavaScript很容易学习

.
.

JS基础

1.注释语法
	// 单行注释
	/*多行注释*/
------------------------------------
2.引入js的多种方式
	1.head内script标签内编写
	2.head内script标签src属性引入外部js资源
	3.body内最底部通过script标签src属性引入外部js资源(最常用)
js代码如果是操作页面上某个标签的,那么这些代码就不能直接写在head里面
------------------------------------
补充:
注意页面的下载是从上往下的,所以操作标签js代码一定要等待标签加载完毕再执行才可以正常运行
--------------------------------------
3.结束符号
	分号(很多时候不写也没问题)

.
.

变量与常量

1.pycharm创建js文件或者html文件(适合编写较为复杂的js代码)
2.浏览器提供编写js代码的环境
-----------------------------------------------------
在js中声明变量需要使用关键字
	var
    	var name = 'jason';
---------------------------------------
	let
    	let name = 'tony';
---------------------------------------
ps:let是ECMA6新语法,可以在局部定义变量名不影响全局   例如:
----------------------------------
var i = 666
for (var i=0;i<10;i++){console.log(i)}

console.log(i)
10
--------------------------------------------------
var i = 666
for (let i=0;i<10;i++){console.log(i)}

console.log(i)
666
---------------------------------------
在js中声明常量也需要使用关键字
	const
    	const pi = 3.14;
申明为常量后,就不能改该常量对应的值了!!!

浏览器里面编js代码如果想要换行,按Shift+回车键 才能换行!!!直接按回车就变成运行了
.
.

基本数据类型

在python中查看对象所属的类用type() 查看
在JS中查看数据类型的方式 typeof
typeof 123          'number'
typeof 12.3          'number'
typeof NaN           'number'

typeof 'jason'           'string'
typeof null              'object'
typeof undefined        'undefined'
typeof Object            'function'

1.数值类型(Number)

1.数值类型(Number)
	在JS中整型与浮点型不分家 都叫Number
	NaN也属于数值类型 意思是:不是一个数字(Not A Number)
---------------------------------------------------------
常用方法

parseInt()   把括号里面的数据转成整型
parseInt("123")        //结果返回123
parseInt(123.45)      //结果返回123
------------------------
虽然类型里面不分整型浮点型,但是转换的时候确支持相关转化
parsefloat()   把括号里面的数据转成整型
parseFloat(123)       //结果返回123
parseFloat("123.1")   //结果返回123.1
想保留数字的小数点就用parseFloat   不想保留小数点就用parseint
-------------------------
parseInt("ABC")       //结果返回NaN
parseFloat("ABC")      //结果返回NaN
--------------------------------------------------------

2.字符类型(String)

2.字符类型(String)
单引号               'jason'
双引号          "jason"
模板字符串    `jason可以放多行文本`

模板字符串的作用:可以格式化输出!!!
let name1 = 'jason'
let age1 = 18
undefined
let desc = `my name is ${name1} my age is ${age1}`
console.log(desc)
my name is jason my age is 18

1.字符串拼接推荐使用加号+
var res = 'hello'+'world'
console.log(res)
helloworld
---------------------------------------------------------

2.常见内置方法

方法 说明
.length 返回长度
.trim() 移除空白
.trimLeft() 移除左边的空白
.trimRight() 移除右边的空白
.charAt(n) 返回第n个字符
.concat(value, ...) 拼接
.indexOf(substring, start) 子序列位置
.substring(from, to) 根据索引获取子序列
.slice(start, end) 切片
.toLowerCase() 小写
.toUpperCase() 大写
.split(delimiter, limit) 分割
let username = '  jason  '

username.length       9

username.trim()        'jason'

username.trimLeft()         'jason  '

username.charAt(2)     'j'

username.concat('8899')       '  jason  8899'     就是两个字符串的拼接

username.indexOf('ja')          2

username.slice(2,5)       'jas'

username.toLowerCase()    '  jason  '

username.toUpperCase()       '  JASON  '

username.split('s')            (2) ['  ja', 'on  ']

username.split('s',1)      ['  ja']

username.split('s',2)           (2) ['  ja', 'on  ']

.
.
.

3.布尔类型(Boolean)

3.布尔类型(Boolean)
	JS里面的布尔值与Python不同
	JS是纯小写的      而Python是首字母大小
----------------------------------------------------------
typeof true
'boolean'
typeof false
'boolean'

typeof True          # js不识别大写字母开头的True
'undefined'

""(空字符串)、0、null、undefined、NaN 对应的布尔值都是false

.
.

4.null与undefined

	null表示值为空(曾经拥有过)
	undefined表示没有定义(从来没有过)

	null表示值是空,一般在需要指定或清空一个变量时才会使用,如 name=null;
	undefined表示当声明一个变量但未初始化时,该变量的默认值是undefined。还有就是函数无明确的返回值时,返回的也是undefined。
----------------------------------------------------------

null 有但是用完了!!!
image
.
undefined表示没有定义(从来没有过)
image
.
.

5.对象(object)

js中一切皆对象!!!
------------------------------------------------
对象之数组(Array)>>>:类似于python中的列表
-----------------------------------------------
定义方式   let l1 = []
--------------------------
常用方法:






















-------------------------------------------------
对象之自定义对象(Object)>>>:类似于python的字典
    let d1 = {'name':'jason',}
    let d2 = new Object();

运算符

1.算术运算符
	+ - * / % ++(自增1) --(自减1)
		var x=10;
    	var res1=x++;  加号在后面	先赋值后自增
    	var res2=++x;	加号在前面	 先自增后赋值
2.比较运算符
	!=(值不等 弱) ==(值相等 弱) ===(值相等 强) !==(值不等 强)
	ps:会不会自动转换类型
3.逻辑运算符
	&&(与)	||(或)  !(非)

流程控制

1.单if分支
	if (条件){
        条件成立执行的代码
    }
2.if...else分支
	if(条件){
        条件成立执行的代码
    }else{
        条件不成立执行的代码
    }
3.if...else if...else分支
	if(条件1){
        条件1成立执行的代码
    }else if(条件2){
        条件1不成立条件2执行的代码
    }
    else{
        条件1和2都不成立执行的代码
    }
4.如果分支结构中else if很多还可以考虑使用switch语法
	switch(条件){
        case 条件1:
        	条件1成立执行的代码;
        	break;  如果没有break会基于某个case一直执行下去
        case 条件2:
        	条件2成立执行的代码;
        	break;
        case 条件3:
        	条件3成立执行的代码;
        	break;
       	case 条件4:
        	条件4成立执行的代码;
        	break;
        default:
  			 条件都不满足执行的代码
    }
 
for循环
	for(起始条件;循环条件;条件处理){
        循环体代码
    }
	for(let i=0;i<10;i++){
       	 console.log(i)
    }
 	let dd = {'name':'jason','age':18}
   for(let k in dd){
        console.log(k)
    }

while循环
	while(循环条件){
        循环体代码
    }
    
"""
三元运算
	python中:   值1 if 条件 else 值2
	JS中:	   条件?值1:值2
"""

函数

"""
python中函数的定义
    def 函数名(形参):
        '''函数注释'''
        函数体代码
        return 返回值
"""
function 函数名(形参){
    // 函数注释
    函数体代码
    return 返回值
}
# 匿名函数
var s1 = function(a, b){
  return a + b;
}
# 箭头函数
var f = v => v;
var f = function(v){
  return v;
}

var f = () => 5;
var f = function(){return 5};

var sum = (num1, num2) => num1 + num2;
var sum = function(num1, num2){
  return num1 + num2;  
}

1.JS中函数的形参与实参个数可以不对应
	传少了就是undefined 传多了不用
2.函数体代码中有一个关键字arguments用来接收所有的实参
3.函数的返回值如果有多个需要自己处理成一个整体

内置对象

var d = new Date(); 
//getDate()                 获取日
//getDay ()                 获取星期
//getMonth ()               获取月(0-11)
//getFullYear ()            获取完整年份
//getYear ()                获取年
//getHours ()               获取小时
//getMinutes ()             获取分钟
//getSeconds ()             获取秒
//getMilliseconds ()        获取毫秒
//getTime ()                返回累计毫秒数(从1970/1/1午夜)


let dd = {name: 'jason', age: 18}
JSON.stringify(dd)	序列化
JSON.parse(ss)	   反序列化


定义正则两种方式
var reg1 = new RegExp("^[a-zA-Z][a-zA-Z0-9]{5,11}");
var reg2 = /^[a-zA-Z][a-zA-Z0-9]{5,9}$/;
1.全局模式的规律
	lastIndex
2.test匹配数据不传默认传undefined

作业

1.编写代码,将当前日期按“2017-12-27 11:11 星期三”格式输出

标签:第四课,username,jason,undefined,代码,JS,---,var,js
From: https://www.cnblogs.com/tengyifan888/p/16953248.html

相关文章

  • js基础
    今日内容概要JS简介变量与常量基本数据类型运算符流程控制函数内置对象今日内容详细JS简介全称JavaScript但是与Java一毛钱关系都没有之所以这么叫是为了......
  • 2-8
    #include<stdio.h>voidone_three(void);voidtwo(void);intmain(){ printf("startingnow:\n"); one_three(); two(); printf("three\n"); printf("done!\n"); return0;......
  • Merge into的注意点之ORA-30926: 无法在源表中获得一组稳定的行?
    原文地址:https://blog.csdn.net/ytfy12/article/details/52488797转自:http://blog.itpub.net/29900383/viewspace-1284128/大家可以看看:http://blog.sina.com.cn/s/blog_......
  • 三秒钟解决MySQL 8.0 Command Line Client打开时闪退的问--小白来搞笑的
    网上地大佬针对解决这个问题的文章都很齐全,大家可以尽情去参考。这里引用一篇,(看了很多之后)我觉得比较全的:https://blog.csdn.net/m0_54695221/article/details/127988332......
  • Nosql--Redis
    一、Nosql概述NoSQL(NoSQL=NotOnlySQL),意即“不仅仅是SQL”,泛指非关系型的数据库。NoSQL不依赖业务逻辑方式存储,而以简单的key-value模式存储。因此大大的增加了数据......
  • python-练习(字符串str与列表list)
    打印字符串"""根据下列文字,提取变量,使用字符串格式化打印信息湖北确诊67802人,治愈63326人,治愈率0.99"""region="湖南"confirmed=67802cure=63......
  • maya-usd编译、安装指南
     1、克隆maya-usd的代码https://github.com/Autodesk/maya-usd2、使用python3.7编译安装usd(参考https://www.cnblogs.com/BstuderBlog/p/15840609.html)3、下载mayasdk......
  • HOW-TO install ffmpeg, Mplayer, mencoder,FLVtool2 and Yamdi on Plesk Linux based
    SologinwithSSHandenterasroot.Weneedtomakesurethecorrectlibdirectoriesaresetupinldconfig.Editthe /etc/ld.so.conf fileandaddthefollowi......
  • 基于Δ-Σ模数转换器的梳状滤波器的设计与matlab仿真
    目录一、理论基础二、核心程序三、测试结果一、理论基础Δ-Σ模数转换器是一种低速,高精度的过采样模数转换器广泛的应用于信号采集和处理、数字通信、自动检测、自动......
  • NCTF2022 - pwn 部分 wp
    总的来说我出的几题不是很难,主要是想把自己感觉有意思的一些东西分享给大家。ezlogin程序设计周大作业稍加改编出的题目。洞在Tea里,有个数组越界写,为了避开\x00截断,我给......