前端入门(一)JavaScript语法、数据类型、运算、函数

文章目录

概念

  • JavaScript是用于浏览器交互操作的脚本语言。
  • 为了确保不同的浏览器上运行的JavaScript标准一致,所以几个公司共同制定了JS的标准命名为ECMAScript

JavaScript编写的位置

  • 写在HTML中的script标签中
  • 写在.js文件中,然后在script标签中使用src引入
  • 写在按钮标签的"onclick"属性中
  • 写在超链接标签"href"属性中

JS既有专门的.js文件,在html文件中使用script标签,添加src属性引入js文件,也可在html文件中直接使用,用script标签,script标签必须成对出现

三个简单的JavaScript语句:

  • alert("弹窗信息"):控制浏览器弹出一个警告框
  • document.write():让计算机在页面中输出一个内容,即向body输出一个内容
  • console.log("控制台输出内容"): 向控制台输出一个内容

js代码也可以写在标签的属性中,但是他们属于结构与行为耦合,不方便维护。

基本语法

  • JS中严格区分大小写
  • JS中每一条语句都以分号(;)结尾,如果不写分号,浏览器会自动添加,但是会消耗一定的系统资源
  • JS中忽略多个空格和换行

JS中只有var类型变量,语句类似于Java。

在浏览器中调试JS需要注意:

Element:元素(html框架)

Console:命令控制台,如console.log(""/var),控制台输出,相当于print

Sources:源码

Network:抓包

Application:应用,查看缓存等

数据类型

  • number: 数字类型,JS中不分小数和整数
  • string:字符串类型
  • boolean:布尔值类型
  • object:对象类型
  • function:函数类型
  • undefined:未定义类型

变量声明var、let、const

letconst是ES6新增的关键字

var、let、const的区别在于:

  • let和var用来声明变量,而const用来声明常量,但是const声明的引用类型是可以改变的
  • var是函数作用域,let是块作用域
    • var是函数作用域,在整个函数内都是有效的,在for循环内定义一个var变量,实际上在for循环外,函数内,都是可以访问的
    • let和const是块级作用域,只在代码块内有效,例如for循环内定义的,for循环外不可访问。 所谓块级作用域,就是用{}包含的区域,我们常用的有for,while,if等。但是在块级作用域中用let声明变量,那么此变量就有了块级作用域,就必须只有在此块级作用域才能访问此变量。
    • const实际保证的并不是变量的值不可变,而是变量指向的内存地址不可变,有点类似Java中的final,因此,对象不可变,对象的属性是可变的。
    • 如果在全局作用域使用var声明变量,此变量会默认成为window的一个属性
    • var声明的变量有变量提升特性,let声明则没有这个特性,所谓变量提升,就是js引擎把变量的声明部分和函数的声明部分提升到代码开头的行为;变量提升后,会给变量默认赋值为undefined

例如下边代码:

javascript 复制代码
console.log(a)
var a = 1

这里会打印undefined,这是因为变量提升后,实际代码是下边这个样子:

javascript 复制代码
var a
console.log(a)
a = 1

undefined与null的区别

  • undefined表示只定义了变量,并没有给变量赋值
  • null表示数值为空值,给变量赋了null

字符串类型

  • 字符串类型用单引号或者双引号包裹
  • 可以使用转译字符'',或者字符模板${变量名},在字符串中引用字符串
  • JS中的字符串是不可变的

数组


Map和Set

函数定义与参数传递


关键字throw,抛出异常,类似汇报异常报告

关键字:arguments,一个包含所有函数输入参数的数组

变量的作用域let、const



全局变量绑定在window的下边

方法的定义与调用


方法.apply(对象1,参数)

apply修饰方法,可以将方法中的this指向为apply的第一个参数,对象名,apply的第二的参数是给方法输入参数赋值

常用内部对象

typeof()

Date()

注:Date(timestamp)可由时间戳返回时间

json

json是数据在传输时的存在形式,在抓包中可以看见。

对象原型

.proto :指向某个对象作为原型,类似父类对象

其实proto只是指向了原型对象,并不是真正意义上的继承,如果对象指定一个原型对象后,当对象再指定第二个原型时,对象有的第一个原型的属性会丢失,即不再与第一个原型有指向关系。。

既然类似Java的继承父类,JS后来引入了class关键字

使用class定义的对象,可以使用new关键字直接继承这个类的属性

也可用extend,在构建子类时继承父类

操作BOM对象

浏览器对象模型(Browser Object Model (BOM))允许 JavaScript 与浏览器对话。

document


操作DOM对象

DOM为网页的文档树,全称是Document Object Model,翻译过来是文档对象模型的意思


  • 在已有节点下追加节点
    使用append给父级节点追加新节点:
  • 创建新的节点

表单操作(验证)+MD5算法检验密码

  • 获取表单信息
  • 表单提交绑定事件
    onsubmit = function/class
html 复制代码
<form action="" method="post" onsubmit="functionName() "></form>

<script>
    function functionName(){
        alert(1)
    }  
  • 按钮绑定事件

onclick = function/class

html 复制代码
<p>
    <input type="button" onclick="functionName()">
</p>


jQuery


jQuery CDN加速

jQuery中文文档

jQuery 使用公式:$选择器().action()

/"拿钱给人办事"/



相关推荐
凤年徐10 分钟前
【数据结构与算法】203.移除链表元素(LeetCode)图文详解
c语言·开发语言·数据结构·算法·leetcode·链表·刷题
心.c12 分钟前
后台管理系统-权限管理
javascript·react.js·github
nbsaas-boot32 分钟前
多租户架构下的多线程处理实践指南
java·开发语言·spring
好困好想睡40 分钟前
认识Promise
javascript
前端_ID林42 分钟前
谈谈JavaScript的异步函数发展历程
javascript
无小道42 分钟前
c++--typedef和#define的用法及区别
c语言·开发语言·汇编·c++
国家不保护废物43 分钟前
深入浅出JavaScript事件循环(event loop):宏任务与微任务的奇幻之旅
前端·javascript·面试
FogLetter44 分钟前
React组件开发之Todos基础:从零打造一个优雅的待办事项应用
前端·javascript·react.js
在钱塘江1 小时前
《你不知道的JavaScript-上卷》第一部分-附录C-笔记-this词法
前端·javascript
胡gh1 小时前
JavaScript 中的闭包、防抖与节流:让你彻底搞懂它们的作用和应用场景
前端·javascript·node.js