JavaScript基础part2(完结)

2024-09-06 06:36
文章标签 java 基础 script part2 完结

本文主要是介绍JavaScript基础part2(完结),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

JavaScript基础

函数

语法

function 函数名(形参表){代码}

代码中加return语句则可以返回值,默认返回值为undefined

两个相同的函数,后面会覆盖前面

命名规则

前缀为动词

传参注意事项

  1. 实参个数 > 形参个数 ==> 没用上的实参被忽略
  2. 实参个数 < 形参个数 ==> 没赋予值得形参为undefined

作用域

全局变量在函数体外定义
局部变量在函数体中定义

访问原则:

有命名冲突,先用局部变量

匿名函数

没有函数名的函数,如何调用

  1. 函数表达式 let fn = function(){}

  2. 立即执行 (function(){})(); 防止变量污染

    多个要用分号隔开,前后都要

案例

函数传参为数组名

let arr = [1, 2, 3, 4]function calArr(a) {let all = 0for (let i = 0; i < a.length; i++) {all += a[i]}document.write(all)}calArr(arr)

局部与全局的区别

function f1() {let num = 123function f2() {console.log(num)}}f2()let num = 456f1()

匿名函数

 //1.函数表达式调用let fn = function () { document.write('hello') }fn();//2.立即执行(function () { document.write('byebye') })();

转换时间

let time = +(prompt('请输入秒数'))//1.小时let hour = parseInt(time / 3600)time -= hour * 3600if (hour < 10) {document.write(`0${hour}h`)} else {document.write(`${hour}h`)}//2.分钟let minute = parseInt(time / 60)time -= minute * 60if (minute < 10) {document.write(`0${minute}m`)} else {document.write(`${minute}m`)}//3.秒数let sec = timeif (sec < 10) {document.write(`0${sec}s`)} else {document.write(`${sec}s`)}

对象

无序的数据集合 ==> 用来描述某个对象:静态特征(属性)和动态行为(方法)

声明语法

let 对象名 = {}let 对象名 = new object()

属性书写语法

uname : '猪猪侠' ,

age : 18

若属性名中有特殊符号,用引号包住

方法书写

方法名 : function(形参表) {代码} ==若后面还有方法需要加,

有特殊符号也可用引号包起

方法调用

对象名.方法名

增删改查

对象名.新属性 = 属性值

delete 对象名.属性名 仅作了解

对象名.已有属性名 = 新属性值

两种方法

  1. 对象名.属性名
  2. 对象名['属性名']

遍历对象

可以用来遍历数组,但不推荐

书写语法

for(let k in 对象名){console.log(对象名[k])}

  • k代表的是属性名,可以用其他字母代替,但最好是kkey

经验

script可以写在body标签的中部,可以更好地进行循环操作


内置对象

JavaScript内部提供的对象 ==> 给开发者调用

  • document.write()
  • console.log()

Math中提供了一系列做数学操作的运算方法

  • random 0~1的随机数,包含0但不包含1
  • ceil 向上取整
  • floor 向下取整
  • max 找最大
  • min 找最小
  • pow 幂运算
  • abs 绝对值

实际应用

N ~ M 之间的随机数

Math.floor(Math.random()*(M - N + 1) + N)

案例

对象声明

let goods = {name: '小米10 青春版',number: '100012816024',weight: '0.05kg',address: '中国大陆'}document.write(goods.name)document.write('</br>')document.write(goods.number)document.write('</br>')document.write(goods.weight)document.write('</br>')document.write(goods.address)document.write('</br>')

对象的增和改

 let goods = {name: '小米10 青春版',number: '100012816024',weight: '0.05kg',address: '中国大陆'}goods.name = '小米10 PLUS'goods.color = 'pink'document.write(goods)

对象的方法调用

let player = {dance: function () {document.write('dance')document.write('</br>')},song: function () {document.write('sing')document.write('</br>')}}//对象方法调用player.dance()player.song()

遍历对象数组

let students = [{ name: '小明', age: 18, gender: '男', hometown: '河北省' },{ name: '小红', age: 19, gender: '女', hometown: '河南省' },{ name: '小刚', age: 17, gender: '男', hometown: '山西省' },{ name: '小丽', age: 18, gender: '女', hometown: '山东省' }]//遍历对象数组for (let i = 0; i < students.length; i++) {for (let k in students[i]) {console.log(students[i][k])}}

数组对象渲染生成表格

<!DOCTYPE html>
<html lang="en"><head><meta charset="UTF-8"><meta name="viewport" content="width=device-width, initial-scale=1.0"><title>Document</title><style>table {width: 600px;text-align: center;}table,th,td {border: 1px solid #ccc;border-collapse: collapse;}caption {font-size: 18px;margin-bottom: 10px;font-weight: 700;}tr {height: 40px;cursor: pointer;}table thead {background-color: #ddd;}table tr:not(。thead):hover {background-color: #eee;}</style>
</head><body><script>let students = [{ name: '小明', age: 18, gender: '男', hometown: '河北省' },{ name: '小红', age: 19, gender: '女', hometown: '河南省' },{ name: '小刚', age: 17, gender: '男', hometown: '山西省' },{ name: '小丽', age: 18, gender: '女', hometown: '山东省' }]document.write(`<table><caption>学生列表</caption><thead><tr class = "thead"><td>序号</td><td>姓名</td><td>年龄</td><td>性别</td><td>家乡</td></tr></thead><tbody>`)for (let i = 0; i < students.length; i++) {document.write(`<tr>`)document.write(`<td>${i + 1}</td>`)for (let k in students[i]) {document.write(`<td>${students[i][k]}</td>`)}document.write(`</tr>`)}document.write(`</tbody>`)</script>
</body></html>

在这里插入图片描述

随机点名案例

 let nameArr = ['赵云', '黄忠', '关羽', '张飞', '马超', '刘备', '曹操']let n = Math.floor(Math.random() * (6 - 0) + 0)document.write(nameArr[n])nameArr.splice(n, 1)document.write(`</br>`)document.write(nameArr)

在这里插入图片描述

猜数字

 let n = Math.floor(Math.random() * (10 - 1) + 1)let num = +(prompt('请输入你要猜的数字'))while (n !== num) {num = +(prompt('猜错了,继续猜'))}alert('终于猜对了老弟')

综合案例

<!DOCTYPE html>
<html lang="en"><head><meta charset="UTF-8"><meta name="viewport" content="width=device-width, initial-scale=1.0"><link rel="stylesheet" href="css/style.css"><title>Document</title>
</head><body><!-- 4. box核心内容区域开始 --><div class="box w"><div class="box-hd"><h3>精品推荐</h3><a href="#">查看全部</a></div><div class="box-bd"><ul class="clearfix"><script>let data = [{src: 'images/course01.png',title: 'Think PHP 5.0 博客系统实战项目演练',num: 1125},{src: 'images/course02.png',title: 'Android 网络动态图片加载实战',num: 357},{src: 'images/course03.png',title: 'Angular2 大前端商城实战项目演练',num: 22250},{src: 'images/course04.png',title: 'Android APP 实战项目演练',num: 389},{src: 'images/course05.png',title: 'UGUI 源码深度分析案例',num: 124},{src: 'images/course06.png',title: 'Kami2首页界面切换效果实战演练',num: 432},{src: 'images/course07.png',title: 'UNITY 从入门到精通实战案例',num: 888},{src: 'images/course08.png',title: 'Cocos 深度学习你不会错过的实战',num: 590},]for (let i = 0; i < data.length; i++) {document.write(`<li><a href="#"><img src=${data[i].src} alt=""><h4>${data[i].title}}</h4><div class="info"><span>高级</span> • <span>${data[i].num}</span>人在学习</div></a></li>`)}</script></ul></div></div>
</body></html>

在这里插入图片描述

注意

代码执行顺序

按照编写顺序,但alert和prompt优先,先于页面渲染执行

数据类型在内存中的情况简单比喻

简单的数据类型将值放在栈空间中,而复杂的数据类型将数据地址放在栈空间中,然后将一系列的值放在堆空间中

思维导图
在这里插入图片描述

这篇关于JavaScript基础part2(完结)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!


原文地址:
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.chinasem.cn/article/1141275

相关文章

Java利用docx4j+Freemarker生成word文档

《Java利用docx4j+Freemarker生成word文档》这篇文章主要为大家详细介绍了Java如何利用docx4j+Freemarker生成word文档,文中的示例代码讲解详细,感兴趣的小伙伴... 目录技术方案maven依赖创建模板文件实现代码技术方案Java 1.8 + docx4j + Fr

SpringBoot首笔交易慢问题排查与优化方案

《SpringBoot首笔交易慢问题排查与优化方案》在我们的微服务项目中,遇到这样的问题:应用启动后,第一笔交易响应耗时高达4、5秒,而后续请求均能在毫秒级完成,这不仅触发监控告警,也极大影响了用户体... 目录问题背景排查步骤1. 日志分析2. 性能工具定位优化方案:提前预热各种资源1. Flowable

Python基础文件操作方法超详细讲解(详解版)

《Python基础文件操作方法超详细讲解(详解版)》文件就是操作系统为用户或应用程序提供的一个读写硬盘的虚拟单位,文件的核心操作就是读和写,:本文主要介绍Python基础文件操作方法超详细讲解的相... 目录一、文件操作1. 文件打开与关闭1.1 打开文件1.2 关闭文件2. 访问模式及说明二、文件读写1.

基于SpringBoot+Mybatis实现Mysql分表

《基于SpringBoot+Mybatis实现Mysql分表》这篇文章主要为大家详细介绍了基于SpringBoot+Mybatis实现Mysql分表的相关知识,文中的示例代码讲解详细,感兴趣的小伙伴可... 目录基本思路定义注解创建ThreadLocal创建拦截器业务处理基本思路1.根据创建时间字段按年进

Java编译生成多个.class文件的原理和作用

《Java编译生成多个.class文件的原理和作用》作为一名经验丰富的开发者,在Java项目中执行编译后,可能会发现一个.java源文件有时会产生多个.class文件,从技术实现层面详细剖析这一现象... 目录一、内部类机制与.class文件生成成员内部类(常规内部类)局部内部类(方法内部类)匿名内部类二、

SpringBoot实现数据库读写分离的3种方法小结

《SpringBoot实现数据库读写分离的3种方法小结》为了提高系统的读写性能和可用性,读写分离是一种经典的数据库架构模式,在SpringBoot应用中,有多种方式可以实现数据库读写分离,本文将介绍三... 目录一、数据库读写分离概述二、方案一:基于AbstractRoutingDataSource实现动态

Springboot @Autowired和@Resource的区别解析

《Springboot@Autowired和@Resource的区别解析》@Resource是JDK提供的注解,只是Spring在实现上提供了这个注解的功能支持,本文给大家介绍Springboot@... 目录【一】定义【1】@Autowired【2】@Resource【二】区别【1】包含的属性不同【2】@

springboot循环依赖问题案例代码及解决办法

《springboot循环依赖问题案例代码及解决办法》在SpringBoot中,如果两个或多个Bean之间存在循环依赖(即BeanA依赖BeanB,而BeanB又依赖BeanA),会导致Spring的... 目录1. 什么是循环依赖?2. 循环依赖的场景案例3. 解决循环依赖的常见方法方法 1:使用 @La

Java枚举类实现Key-Value映射的多种实现方式

《Java枚举类实现Key-Value映射的多种实现方式》在Java开发中,枚举(Enum)是一种特殊的类,本文将详细介绍Java枚举类实现key-value映射的多种方式,有需要的小伙伴可以根据需要... 目录前言一、基础实现方式1.1 为枚举添加属性和构造方法二、http://www.cppcns.co

Elasticsearch 在 Java 中的使用教程

《Elasticsearch在Java中的使用教程》Elasticsearch是一个分布式搜索和分析引擎,基于ApacheLucene构建,能够实现实时数据的存储、搜索、和分析,它广泛应用于全文... 目录1. Elasticsearch 简介2. 环境准备2.1 安装 Elasticsearch2.2 J