java 80_【JavaWeb】80:js基础详解

今天是刘小爱自学Java的第80天。

感谢你的观看,谢谢你。

话不多说,开始今天的学习:

b258570ab4f6b72f1eae79228b8f6f2a.png

JavaScript是一门编程语言,但凡是编程语言,其在基本语法上都是大同小异的。

我们学了Java,那么再学习其它语言时,学它不同于Java的地方即可,这样也能更好地记忆。

一、js中的运算符

1算术运算符

无外乎就是加减乘除,取模,自增自减这些,用法和Java中都是一样的。

但js中的运算也有和Java的不同之处;

1794562db6754c33a6aa851dd562b763.png

①变量之间的运算

在js中,不同数据类型之间的变量也能运算。

100和true相加结果竟然是101,这在Java中会直接报错,因为不确定结果是什么数据类型。

所以在js中,true参与运算时就相当于数字1,同理false就相当于数字0,null也是相当于数字0

②undefined类型参与运算

变量c没有定义,所以是未定义类型,当其参与运算时得到的结果为NaN。

未定义类型和非字符串任意类型运算时,得到的结果都是NaN。

NaN,全称not a number,不是一个数字。

③string类型参与运算

这个和Java中倒是一样,任意类型和string类型相加时,结果都是拼接。

但是String在Java里面是引用数据类型,而在js里面是基本(原始)数据类型。

2逻辑运算

关于逻辑运算符:与(&&)、或(||)、非(!)和Java中是一样的。

但在js中的逻辑判断与Java有些不同:

48b48b66f87bf6cc13c93bfd2ef05c43.png

①布尔表达式

这个也就和Java中一样,逻辑判断为true时结果为真,逻辑判断为false时结果为假。

②数字作为布尔表达式

在js里面,数字也有自己的逻辑判断:

当数字不为0时,逻辑判断为true;

当数字为0时,逻辑判断为false。

③字符串作为布尔表达式

当字符串不为空时,逻辑判断为true;

当字符串为空时,逻辑判断为false。

此外,未定义数据类型逻辑判断也为false,在算术运算中的NaN作为逻辑判断时也为false。

我就不一一演示了。

3比较运算符

其中js中的赋值运算符(=、+=、-=、*=、/=、%=)和Java中一样。

比较运算符(==、!=、、>=)也和Java中一样,但js有两个个特殊的比较运算符:

b2fb6cc755c384b30789f2385e063a1a.png

①字符串与数字比较

在js中,字符串也能参与比较,会先将其转换成数字再进行比较。

==,等于,比较的是值是否相等。

===,恒等于,比较的是值和类型均相等。

②null与未定义比较

同样的道理,它们的值相等,都为null,但是类型不一样,所以不恒等于。

4三目运算符

也就是Java中的三元运算符。

二、js中的函数

1函数定义

js中的函数其实也就是Java中的方法。

64776c1ac6a3c9706793b3ca0350b1c0.png

①Java中的方法

做一个回顾,Java方法格式:修饰符+返回值+方法名+(参数列表)+{方法体};

其中参数列表中要明确数据类型。

②js中的函数

js函数格式:fuction+方法名(参数列表){};

js中不仅没有修饰符,连返回值都没有,并且参数列表的数据类型不用明确。

由此可以看出:js的语法相对于Java而言较为随意,不像Java那么严谨,但确实简便了很多。

2实参和形参

实参:调用函数时的参数(传入的具体数值)。

形参:定义函数时的参数(自定义的变量)。

Java中形参与实参要明确保证一致(数量、数据类型都要保证一致)

但是js中可以不一致,我们逐一分析:

3b54174f5ca2fc07fdd2add750c66634.png

①实参与形参数量不一致

实参与形参的关系相当于将实参的值赋给形参。

当实参比形参要少时:a=1;b=2,但是c未定义。

在js中任何数据与未定义的变量相加都是NaN。

当实参和形参一样或者多时,结果没有影响,多的实参不参与运算即可。

②形参和方法体中的变量不一致

如果方法体中的变量要少,有几个就用几个。

如果方法体中的变量要多,多了一个形参中没有的变量d,则无法运行。

这个Java中倒是有一定的相似之处。

3参数arguments

事实上在js中有一个专门的数组arguments,用来接收调用时的实际参数:

e63241a7910e28212bcd794d168e3f46.png

js中的数组是可变的,所以可以使用这种方式来接受,当然也可以使用for循环来处理。

不过要注意的是,js中可没有增强for循环。

老实说,对于arguments这个概念,其实也就相当于是实际参数,知道在js中有它的存在即可。

我个人对于实参和形参的理解,就是将实参赋值给形参再参与运算,这样方便记忆也好理解。

4返回值和方法重载

d35c070432f7b00d2bb5d55d4f6dc62d.png

①返回值

js在定义函数时是不用说明返回值的,如果有返回值,直接return即可。

②方法(函数)重载

在Java中是有方法重载(同名不同参)

但是在js中是没有方法重载的。

这也好理解,在Java中参数类型不同,个数不同即代表不同的参数。

但是在js中参数类型都没有明确定义,所以也没法区分参数不同,并且实参个数与形参个数没有关系。

其中,js代码是从上到下执行的,同名函数,后面的函数会覆盖前面的函数。

5局部变量和全局变量

c0166cfba819331e8adbdcc1cb478287.png

①函数内测试局部变量

函数内部,局部变量和全局变量都可以访问。

②函数外测试全局变量

在函数外部,局部变量是不能被访问的,但是全局变量可以访问。

③另一个script标签

和函数外部一样的道理,通过②③我们可以得出结论:变量c是一个全局变量。

事实上,当局部变量省略了var的时候,会变成全局变量。

为什么会这样?画图分析:

382a82a75d14c971b1127a5854665421.png

也就是说实际上变量c省略了var,就相当于默认在外部定义了var c,再在函数内赋值。

当然其前提是该变量没有在函数内被定义,如果变量c在函数内定义过了,那它就是个局部变量。

④测试思考

我发现明明a,c都是全局变量,a,c中间加了一个b后,c就不能打印了。

也就是说外部是没法引用局部变量的,会报错。

但是js中报错了照样能运行,只是当前标签内后面的代码就不执行了。

最后

谢谢你的观看。

如果可以的话,麻烦帮忙点个赞,谢谢你。

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

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

相关文章

php manager iis 8,PHPManager2下载

PHP Manager 2.x 理论支持win10,win8,win7,Windows Server2008,Windows Server2012,Windows Server2012R2,Windows Server2016,,Windows Server2019与其对应的IIS版本.--PHP Manager 2.4 for IIS10,IIS8,IIS7 下载简单但功能强大具有独特功能的工具,可以处理所有细节…

企业知识库:从信息管理到知识创新的转变

在当今这个信息爆炸的时代,企业知识库的建设已经成为了企业持续发展的重要基石。从传统的信息管理到现代的知识创新,企业知识库的角色和功能也在不断地演变和升级。本文将探讨企业知识库的发展历程,以及如何实现从信息管理到知识创新的转变。…

php封装的数据库操作文件夹,PHP中对数据库操作的封装_php

现在我们把其封装在dbfz.inc中,其设计如下:$#60;?class dbInterface{ var $dbID1; //用于确定当前操作的数据库,当dbID为1代表mysql,当为 2代表 SQL Server,为3时为ODBC或其它。var $dbHost; //数据库所在主机域名var $dbUsernam…

Spring框架架构

这是Spring Framework Architecture的概述。 了解Spring Framework的各个组成部分如何组织以及如何相互联系。 如果您想了解什么是Spring框架及其功能,请阅读Spring框架简介 。 总览 Spring是一个模块化框架 。 它不是作为一个软件包或多个模块捆绑在一起的。 各种…

php中n12br,PHP常见字符串操作函数与用法总结

一、字符串的格式化1、字符串的格式化trim()函数可以去除字符串的开始位置和结束位置的空格,并将结果字符串返回,默认情况下去除的字符是换行符和回车符(\n和\r),水平和垂直制表符(\t和X0B)ltrim()函数只从字符的开始处(左边)去除空格rtrim()函数只从函数…

面向切面编程应用_应用面向方面的编程

面向切面编程应用1.引言 面向方面编程的主要目标是将跨领域关注点分离。 当我们谈论跨领域的关注时,我们指的是在我们的系统或应用程序中的多个地方使用的通用功能。 这些概念包括: 记录中 交易管理 错误处理 监控方式 安全 实现这种分离的方法是将…

centos 安装php扩展gd,linux(centos)下为php添加添加GD扩展

yum -y install libjpeglibjpeg-devel libpng libpng-devel freetype freetype-devel 安装依赖库yum -y install libjpeg-devel1.首先切换到php源码目录:/usr/local/php-5.6.29/ext/gd2.利用phpize生成gd扩展文件,/usr/local/php/bin/mipsel-linux-phpize, ls 或者 …

弹簧启动执行器教程

朋友您好,在本教程中,我们将学习弹簧执行器及其所有功能。 1.什么是弹簧执行器? 2.如何在Maven项目或Gradle项目中添加弹簧执行器? 3.创建一个具有Spring Actuator依赖项的Spring Boot项目。 4.使用弹簧执行器端点监视应用程序…

php xls 邮件,PHPMailer发送邮件

PHPMailer是一个封装好的PHP邮件发送类,支持发送HTML内容的电子邮件,以及图片附件,前提要设置好邮件服务器就能实现邮件发送功能。HTML首先我们先放置一个收件箱的输入框和一个发送邮件按钮:收件人:jQuery$(function()…

引导性GCP:带有Google Cloud Pub / Sub的Spring Cloud Stream

我最近在Sprint Central的工程博客上阅读了Josh Long的Bootiful GCP系列 ,特别喜欢关于使用Google Cloud的Pub / Sub的第四部分 。 我受到该系列的启发,同时我还在为我的一个新项目评估Spring Cloud Stream。 我以为,我会继续讨论乔希&#x…

jdbc和jdbc驱动_JDBC布尔兼容性列表

jdbc和jdbc驱动有趣的是,布尔类型只是在SQL标准后期才引入,即SQL:1999 。 即使在今天,并非所有数据库本身都支持BOOLEAN或BIT类型。 最重要的是,我们仍然可以在Oracle中等待一段时间。 这是2002年以来关于该主题的“问…

IDE日志分析方法pt。 1个

介绍 我认为大多数软件工程师都了解日志的重要性。 它们已成为软件开发的一部分。 如果无法解决问题,我们尝试在日志中查找原因。 对于一些简单的情况,当错误阻止应用程序打开窗口时,这可能就足够了。 您可以在日志中找到问题,然后…

java运行构建期间出错_构建和运行Java 8支持

java运行构建期间出错尚未提供对Java 8的Eclipse支持。 如果要使用它,则必须构建它。 Eclipsepedia的JDT Core / Java8页面包含有关使用Eclipse Java开发工具 (JDT)中不断发展的Java 8支持源来设置开发环境的说明。 说明中缺少一些内容&#…

从Commons CLI迁移到picocli

最初于2002年发布的Apache Commons CLI可能是使用最广泛的Java命令行解析器,但是它的API显示了它的年龄。 寻找具有最少样板代码的现代方法的应用可能对picocli感兴趣。 为什么要花麻烦的钱进行迁移,以及如何将基于Commons CLI的应用程序迁移到picocli&a…

QuickBooks和Sage数据导出器

许多中小企业都使用QuickBooks作为其会计模块。 同样,许多公司也使用Sage进行会计处理。 他们中的大多数人在需要从这些系统中导出数据时会遇到问题。 在线提供的许多连接器价格昂贵,无法满足确切的要求。 随附的是一些简短的代码段,这些代码…

php内容缓存输出,PHP使用缓存即时输出内容(output buffering)的方法

PHP使用缓存即时输出内容(output buffering)的方法PHP使用缓存即时输出内容(output buffering)的方法。分享给大家供大家参考。具体如下:$buffer ini_get(output_buffering);echo str_repeat( ,$buffer1); //防止浏览器缓存ob_end_flush(); //关闭缓存for( $i1; $i…

继承能够访问父类私有字段_在单元测试中访问私有字段

继承能够访问父类私有字段首先,让我大声说一下,您需要将代码设计为可测试的,以便通过公共方法测试私有字段。 但是,(“ buts”是人们仍在编程而不是计算机本身的原因,所以在这里很高兴)有时您想…

甲骨文函数初探

我非常高兴有机会通过Cloud Native Limited Availability Program来测试Oracle功能。 去年,当我上次尝试在Oracle Groundbreaker APAC巡回赛中在Oracle Cloud中运行无服务器功能时,有两种选择。 您可以在虚拟机中运行我自己的Fn服务器,也可以…

spring roo_使用Spring Roo进行概念验证

spring roo在Keyhole工作期间,我参与了许多项目,其中客户要求我们重写旧系统,同时保留其现有数据库。 有时,它有助于快速演示如何使用当前技术来简化开发,测试和维护其代码。 我发现可以创建一个快速示例(…

oracle虚拟机怎么装系统,Virtualbox怎么安装系统 VirtualBox虚拟机安装Win8系统教程 (3)...

三、对新建的虚拟机做重要的设定:1、在Oracle VM VirtualBox里面点击下刚才建好的虚拟机,然后点下上面的黄色图标“设置”,或者右键菜单里面点击设置也可以(快捷键是CtrlS)Oracle VM VirtualBox虚拟机设置2、在出来的设置页面里面&#xff0c…