JavaScript基础知识点总结:从零开始学习JavaScript(六)

news2025/1/20 12:04:15

 

本章内容主要让小伙伴们自主练习 ,建议大家先自己写出来答案,然后对照我的!(题不难主要培养自己的编程思维!!!)

如果大家感感兴趣也可以去看:

🎉博客主页:阿猫的故乡

🎉系列专栏:JavaScript专题栏

🎉ajax专栏:ajax知识点

🎉欢迎关注:👍点赞🙌收藏✍️留言

学习目标:

  • 笔试题→锻炼基本语法的掌握

  • 排错题→锻炼编码过程中常见错误的解决

  • 编程题→基于课堂练习和每日作业的常见编程思维的训练


学习内容:

笔试题:

  1. 什么是JavaScript?

  2. JavaScript的历史和发展简介。

  3. JavaScript中的变量声明有哪些关键字?它们之间有什么区别?

  4. JavaScript中如何创建函数?

  5. JavaScript中的条件语句有哪些?请举例说明。

  6. JavaScript中的循环语句有哪些?请举例说明。

  7. JavaScript中如何处理异常?请举例说明。

  8. JavaScript中的数组是如何定义和使用的?请给出一个数组的操作示例。

  9. 如何在JavaScript中定义和访问对象的属性?请给出一个对象的操作示例。

  10. JavaScript中的DOM是什么?如何使用JavaScript操作DOM元素?请举例说明。

 排错题:

 

当然,下面是5道JavaScript代码的常见错误题目:

  1. 请找出以下代码中的错误并改正:
let x = 5;
if (x == 5) {
  console.log("x is equal to five!");
} else {
  console.log("x is not equal to five!");
}

  1. 请找出以下代码中的错误并改正:
function multiply(a, b) {
  return a * b;
}
let result = multiply(2, 3);
console.log(result);

  1. 请找出以下代码中的错误并改正:
let numbers = [1, 2, 3, 4, 5];
for (let i = 0; i <= numbers.length; i++) {
  console.log(numbers[i]);
}

  1. 请找出以下代码中的错误并改正:
let person = {
  name: "John",
  age: 25,
  occupation: "developer"
};
console.log(person.name);
console.log(person.occupation);

  1. 请找出以下代码中的错误并改正:
let x = 10;
let y = "5";
let sum = x + y;
console.log(sum);

希望这些题目能够帮助你加深对JavaScript的理解,如果你需要更多的题目,请随时告诉我。

 编程题:

  1. 编写一个JavaScript程序,输出所有小于100的偶数。

  2. 编写一个JavaScript程序,计算并输出1到10的平方数。

  3. 编写一个JavaScript函数,接收一个数字参数n,然后输出1到n之间所有的奇数。

  4. 编写一个JavaScript函数,接收一个字符串参数,然后判断该字符串是否是回文(正向和反向读取都一样)。

  5. 编写一个JavaScript函数,接收一个数组参数,然后返回该数组中的最大值和最小值。

  6. 编写一个JavaScript程序,接收一个数字参数n,然后输出n的阶乘。

  7. 编写一个JavaScript程序,接收一个字符串参数,然后输出该字符串的长度。

  8. 编写一个JavaScript函数,接收一个数组参数,然后返回该数组中所有元素的总和。

  9. 编写一个JavaScript函数,接收两个数字参数,然后返回它们的乘积。

  10. 编写一个JavaScript函数,接收两个数组参数,然后返回它们的交集。


学习时间:

  • 周一至周五晚上 7 点—晚上9点
  • 周六上午 9 点-上午 11 点
  • 周日下午 3 点-下午 6 点

学习产出:

笔试题答案:

 

  1. JavaScript是一种脚本语言,用于为网页添加交互性和动态性。它可以在网页中嵌入HTML代码,并通过浏览器解释和执行。

  2. JavaScript的历史和发展简介:

    • 1995年,由Netscape公司的Brendan Eich开发出原始的JavaScript(当时称为LiveScript)。
    • 1996年,为了标准化,JavaScript被提交给ECMA(欧洲计算机制造商协会)进行标准化工作,最终成为ECMAScript标准。
    • 1997年,发布了第一个ECMAScript标准的版本(ECMAScript 1),随后陆续有更多的版本发布,如ES2、ES3、ES5等。
    • 2009年,出现了ECMAScript 5.1版本,带来了许多新的特性和改进。
    • 2015年,发布了ECMAScript 6(也称为ES6或ES2015)标准,引入了许多重要的语言特性和改进。
  3. JavaScript中的变量声明关键字有三个:var、let和const。

    • var:用于声明一个变量,其作用域为函数级别。
    • let:用于声明一个块级作用域的变量,其作用范围只在当前代码块内。
    • const:用于声明一个常量,其值无法被重新赋值。
  4. 在JavaScript中,可以使用function关键字来创建函数。函数可以有参数和返回值,可以执行一系列的操作和逻辑。 例如,以下是一个简单的函数定义:

    function add(a, b) {
      return a + b;
    }
    

  5. JavaScript中的条件语句有if语句、if...else语句和switch语句。

    • if语句用于在满足条件时执行一段代码块。
    • if...else语句用于在满足条件时执行一段代码块,否则执行另一段代码块。
    • switch语句用于根据不同的情况执行不同的代码块。 例如,以下是一个使用if语句的示例:
    let num = 10;
    if (num > 0) {
      console.log("Number is positive");
    }
    

  6. JavaScript中的循环语句有for循环、while循环和do...while循环。

    • for循环用于重复执行一段代码指定的次数。
    • while循环用于在满足条件时重复执行一段代码。
    • do...while循环与while循环类似,但它会先执行一次代码块,然后再检查条件。 例如,以下是一个使用for循环的示例:
    for (let i = 0; i < 5; i++) {
      console.log(i);
    }
    

  7. JavaScript中可以使用try...catch语句来处理异常。try代码块中包含可能会引发异常的代码,catch代码块用于捕获并处理异常。 例如,以下是一个处理异常的示例:

    try {
      throw new Error("Something went wrong");
    } catch (error) {
      console.log(error.message);
    }
    

  8. JavaScript中的数组可以通过使用方括号[]来定义,并且可以包含任意类型的元素。 以下是一个数组的操作示例:

    let fruits = ["apple", "banana", "orange"];
    console.log(fruits[0]); // 输出: "apple"
    fruits.push("grape");   // 添加元素到数组末尾
    fruits.pop();           // 删除数组末尾的元素
    console.log(fruits.length); // 输出: 3
    

  9. 在JavaScript中,可以使用点号(.)或方括号([])来定义和访问对象的属性。 以下是一个对象的操作示例:

    let person = {
      name: "John",
      age: 25,
      "phone number": "1234567890"
    };
    console.log(person.name); // 输出: "John"
    console.log(person["age"]); // 输出: 25
    

  10. DOM(Document Object Model)是指将HTML文档表示为一个树形结构的方式,JavaScript可以通过操作DOM元素来改变页面的内容、样式和行为。 可以使用document对象的方法和属性来操作DOM元素,例如getElementById()、querySelector()、createElement()等。 以下是一个使用JavaScript操作DOM元素的示例:

    // 根据id获取元素,并修改其内容
    let element = document.getElementById("myElement");
    element.innerHTML = "New content";
    
    // 创建一个新的元素,并添加到页面中
    let newElement = document.createElement("div");
    newElement.innerHTML = "New element";
    document.body.appendChild(newElement);
    

 拍错题答案:

 

答案如下:

  1. 错误:在条件语句中使用的是赋值操作符"="而不是判断相等的操作符"=="。 改正:将条件语句修改为if (x === 5)

  2. 无错误。

  3. 错误:循环条件中的i &lt;= numbers.length导致数组越界。 改正:将循环条件修改为i &lt; numbers.length

  4. 无错误。

  5. 错误:将数字和字符串相加会将数字转换为字符串并进行拼接,而不是进行数值相加。 改正:将变量y的类型修改为数字类型。

let x = 10;
let y = 5;
let sum = x + y;
console.log(sum); // 输出15

编程题:

 

  1. 输出所有小于100的偶数:
for(let i = 2; i < 100; i += 2) {
  console.log(i);
}

  1. 计算并输出1到10的平方数:
for(let i = 1; i <= 10; i++) {
  console.log(i ** 2);
}

  1. 输出1到n之间所有的奇数:
function printOddNumbers(n) {
  for(let i = 1; i <= n; i += 2) {
    console.log(i);
  }
}

printOddNumbers(10);

  1. 判断字符串是否为回文:
function isPalindrome(str) {
  let reversedStr = str.split('').reverse().join('');
  return str === reversedStr;
}

console.log(isPalindrome('level')); // true
console.log(isPalindrome('hello')); // false

  1. 返回数组中的最大值和最小值:
function findMinMax(arr) {
  let min = Math.min(...arr);
  let max = Math.max(...arr);
  return { min, max };
}

console.log(findMinMax([1, 2, 3, 4, 5])); // { min: 1, max: 5 }

  1. 计算n的阶乘:
function factorial(n) {
  if(n === 0 || n === 1) {
    return 1;
  }
  else {
    return n * factorial(n - 1);
  }
}

console.log(factorial(5)); // 120

  1. 输出字符串的长度:
let str = 'Hello World';
console.log(str.length); // 11

  1. 返回数组中所有元素的总和:
function sumArray(arr) {
  let sum = arr.reduce((acc, curr) => acc + curr, 0);
  return sum;
}

console.log(sumArray([1, 2, 3, 4, 5])); // 15

  1. 返回两个数字的乘积:
function multiplyNumbers(a, b) {
  return a * b;
}

console.log(multiplyNumbers(5, 6)); // 30

  1. 返回两个数组的交集:
function intersection(arr1, arr2) {
  let result = arr1.filter(value => arr2.includes(value));
  return result;
}

console.log(intersection([1, 2, 3], [2, 3, 4])); // [2, 3]


文章出自:http://www.whnw.com.cn/news/1705051.html

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

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

Python跨年烟花秀

写在前面 今年跨年怎么过呢~博主用python的pygame实现了一场炫酷的烟花秀&#xff0c;一起来看看吧&#xff01; 环境需求 python3.11.4及以上PyCharm Community Edition 2023.2.5pyinstaller6.2.0&#xff08;可选&#xff0c;这个库用于打包&#xff0c;使程序没有python环境…

C#高级 08Json操作

1.概念 Json是存储和交换文本信息的语法。类似于XML。Json比XML更小、更快、更易解析。Json与XML一样是一种数据格式。Json是一种轻量级的数据交换格式。它基于ECMAScript的一个子集。Json采取完全独立于语言的文本格式&#xff0c; 但是也使用了类似于C语言的习惯。这些特性使…

这儿有一道SPSS回归分析考试题,大家学会了吗?

为研究某地区房地产市场的价格与相关影响因素之间的关系&#xff0c;现从该地区采集了 20 份样本&#xff0c;数据如下表&#xff0c;请给出销售价格与相关影响因素之间的函数表达式&#xff0c;并从统计学角度分析这些因素之间的关系&#xff0c;最后预测 X 小区的平均销售价格…

java中的缓冲类HeapByteBuffer和DirectByteBuffer的区别

使用之前写的文章里的例子 https://blog.csdn.net/zlpzlpzyd/article/details/135292683 HeapByteBuffer import java.io.File; import java.io.FileInputStream; import java.io.Serializable; import java.nio.ByteBuffer; import java.nio.channels.FileChannel;public clas…

Tomcat与Servlet是什么关系

Tomcat与Servlet是什么关系 Apache Tomcat和Servlet之间存在密切的关系&#xff0c;可以说它们是一对密切合作的组件。下面是它们的关系&#xff1a; Tomcat是Servlet容器&#xff1a; Tomcat是一个开源的、轻量级的Servlet容器。Servlet容器是一个Web服务器扩展&#xff0c;用…

经典文献阅读之--OccNeRF(基于神经辐射场的自监督多相机占用预测)

0. 简介 作为基于视觉感知的基本任务&#xff0c;3D占据预测重建了周围环境的3D结构。它为自动驾驶规划和导航提供了详细信息。然而&#xff0c;大多数现有方法严重依赖于激光雷达点云来生成占据地面真实性&#xff0c;而这在基于视觉的系统中是不可用的。之前我们介绍了《经典…

php获取访客IP、UA、操作系统、浏览器等信息

最近有个需求就是获取下本地的ip地址、网上搜索了相关的教程&#xff0c;总结一下分享给大家、有需要的小伙伴可以参考一下 一、简单的获取 User Agent 信息代码: echo $_SERVER[HTTP_USER_AGENT]; 二、获取访客操作系统信息: /** * 获取客户端操作系统信息,包括win10 * pa…

一语道破爬虫,来揭开爬虫面纱

目录 一、爬虫&#xff08;网络蜘蛛(Spider)&#xff09; 1.1、是什么&#xff1a; 1.2、学习的原因 1.3、用在地方&#xff1a; 1.4、是否合法&#xff1a; 1.5、后果 案例&#xff1a; 二、应用领域 三、Robots协议 四、抓包 4.1、浏览器抓包 4.2、抓包工具 常见…

DDAE: Denoising Diffusion Autoencoders are Unified Self-supervised Learners

DDAE: Denoising Diffusion Autoencoders are Unified Self-supervised Learners Paper&#xff1a;https://arxiv.org/abs/2303.09769 Code&#xff1a;https://github.com/FutureXiang/ddae TL; DR&#xff1a;扩散模型的训练其实就是训练一个去噪模型&#xff0c;考虑到类似…

竞赛保研 基于机器视觉的12306验证码识别

文章目录 0 简介1 数据收集2 识别过程3 网络构建4 数据读取5 模型训练6 加入Dropout层7 数据增强8 迁移学习9 结果9 最后 0 简介 &#x1f525; 优质竞赛项目系列&#xff0c;今天要分享的是 基于机器视觉的12306验证码识别 该项目较为新颖&#xff0c;适合作为竞赛课题方向…

Harmony全局应用生命周期 EntryAbility.ts 讲解

之前 我们说过 page页面的生命周期 组件的生命周期 其实他和uni一样有一个整个应用的生命周期 我们如下图打开EntryAbility.ts 这是我们整个程序app的状态控制 他这里也有几个全局的生命周期 比如 我们手机 点开当前 App 启动 app 会触发 它的 onCreate 生命周期 当我们从手…

【并发设计模式】聊聊等待唤醒机制的规范实现

在多线程编程中&#xff0c;其实就是分工、协作、互斥。在很多场景中&#xff0c;比如A执行的过程中需要同步等待另外一个线程处理的结果&#xff0c;这种方式下&#xff0c;就是一种等待唤醒的机制。本篇我们来讲述等待唤醒机制的三种实现&#xff0c;以及对应的应用场景。 G…

Linux:apache优化(5)—— 隐藏版本号

防盗链&#xff1a;就是防止别人盗取你们公司的图片、文件、视频 作用&#xff1a;防盗链就是防止别人盗用服务器中的图片、文件、视频等相关资源。运维人员可以通过apache提供rewrite模块进行优化。 配置项&#xff1a; RewriteEngine ON ##打开网页重写功能 RewriteCond …

微服务全链路灰度方案介绍

目录 一、单体架构下的服务发布 1.1 蓝绿发布 二、微服务架构下的服务发布 三、微服务场景下服务发布的问题 四、全链路灰度解决方案 4.1 物理环境隔离 4.2 逻辑环境隔离 4.3 全链路灰度方案实现技术 4.3.1 标签路由 4.3.2 节点打标 4.3.3 流量染色 4.3.4 分布式链路…

基于ssm的程序设计实践项目管理系统+jsp论文

摘 要 现代经济快节奏发展以及不断完善升级的信息化技术&#xff0c;让传统数据信息的管理升级为软件存储&#xff0c;归纳&#xff0c;集中处理数据信息的管理方式。本实践项目管理系统就是在这样的大环境下诞生&#xff0c;其可以帮助管理者在短时间内处理完毕庞大的数据信息…

2023跨境电商年度总结:好用的跨境电商工具集合

不知不觉2023年已到了尾声&#xff0c;迎来崭新的2024年。经过年末旺季冲击的跨境电商&#xff0c;也来到了总结阶段。常言道工具选的好&#xff0c;工作轻松倍。在我们的跨境工作中少不得那些高效有用的工具加持。 接下来小编为大家盘点2023年度跨境工具网站&#xff0c;快来…

shell编程一

shell 定义 Shell 也是一种程序设计语言&#xff0c;它有变量&#xff0c;关键字&#xff0c;各种控制语句&#xff0c;有自己的语法结构&#xff0c;利用shell程序设计语 可以编写功能强、代码简短的程序 #! Shebang 定义解释器 shell的分类和切换 # cat /etc/shells /bin/sh…

AI大模型:未来科技的新篇章

目录 1AI大模型&#xff1a;未来科技的新篇章 2AI超越数学家攻克经典数学难题&#xff1b;非侵入式设备解码大脑思维 1AI大模型&#xff1a;未来科技的新篇章 随着科技的飞速发展&#xff0c;人工智能&#xff08;AI&#xff09;已经成为了我们生活中不可或缺的一部分。而AI大…

Ubuntu22.04 安装教程

系统下载 Ubuntu官网下载 清华源镜像 安装流程 1. 选择安装语言 2. 选择是否在安装时更新 为了系统安装速度一般选择安装时不更新&#xff0c;安装后自行更新 3. 选择系统语言和键盘布局 4. 选择安装模式 5. 配置网络信息 6. 设置静态IP 7. 配置代理信息 8. 配置Ubuntu镜像…