- 使用 Spring Initializr 创建 Spring Boot 应用程序
- 在Spring Boot中配置Cassandra
- 在 Spring Boot 上配置 Tomcat 连接池
- 将Camel消息路由到嵌入WildFly的Artemis上
JavaScript(简称 JS):
语言 | 用处 | 关系 |
---|---|---|
HTML | 用来定义网页的内容 | 是网页的结构(骨) |
CSS | 用来规定网页的布局 | 是网页的样式(皮) |
JavaScript | 用来对网页进行编程 | 是网页的行为(魂) |
补充:
上述一系列的加载、翻译、执行的过程都是由浏览器来执行的
浏览器分成渲染引擎和 JS 引擎
渲染引擎:用来解析 HTML 和 CSS,俗称内核
JS 引擎:是 JS 的解释器,典型的就是 Chrome 中的 V8
在浏览器端运行的 JavaScript 由以下三部分组成:
注意:
基本介绍: 直接嵌入到 html 元素内部
示例代码:
<input type="button" value="我是按钮" onclick="alert('我出现啦!')">
补充: alert 的功能就是弹出一个对话框,参数就是对话框显示的内容
基本介绍: 放到 script 标签中
示例代码:
<script>
alert("haha");
</script>
基本介绍: 写到单独的 js 文件中
注意: 这种情况下,script 标签中间不能写代码,写了也不会执行
示例代码:
alert("haha");
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta http-equiv="X-UA-Compatible" content="IE=edge">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>test1</title>
<script src="haha.js"></script>
</head>
<body>
</body>
</html>
基本介绍:
//
// 我是单行注释
/* */
/*
我是多行注释
我是多行注释
*/
注意:
Ctrl + /
快速注释基本介绍: 弹出一个输入框
示例代码:
prompt("请输入你的姓名:");
基本介绍: 弹出一个警示对话框,输出结果
示例代码:
alert("我是大魔王");
基本介绍: 在控制台打印一个日志
注意: 需要打开浏览器的开发者工具(F12),在 Console 标签页才能看到结果
示例代码:
console.log("这是一条日志");
console
是 js 中的一个对象,表示控制台.
表示取对象中的某个属性或者方法console.log
可以理解为使用控制台对象的 log 方法基本介绍: 变量的创建有两个关键字可以使用,分别是 var 和 let
var name = '大魔王';
var name = 20;
let name = 'abc';
let money=30.5;
注意:
示例代码:
let name = prompt("请输入你的姓名:");
let age = prompt("请输入你的年龄:");
alert("你的姓名是:" + name + "\n" + "你的年龄是:" + age);
JS 中的变量是动态类型的,意思是变量的类型可以在程序运行过程中发生改变,例如
// 将字符串类型的 name 变量改为 数字类型
let name = '大魔王';
console.log(name);
name = 13;
console.log(name);
JS 中内置了几种数据类型类型:
基本介绍: JS 中不区分整数和浮点数,统一用数字类型 number 来表示
示例代码:
let a = 10;
let b = 2.5;
console.log(a);
console.log(b);
数字进制表示:
// a的十进制值为7
let a = 07;
// a的十进制为7
let a = 0x7;
// a的十进制为7
let a = 0b111
特殊的数字值: 当变量的值为浮点数时,会有以下三个特殊的值
// Number.MAX_VALUE 为 JS 的最大值
let max = Number.MAX_VALUE;
// 得到 Infinity
console.log(2*max);
// 得到 -Infinity
console.log(-2*max);
// 得到 NaN
console.log('abc' + 10);
基本介绍: 将字面值用单引号或者双引号括起来表示字符类型
示例代码:
let a = "abc";
let b = '大魔王';
字符串本身包含引号的写法:
let s1 = 'I am "Peter"';
let s2 = "I am 'Peter''";
\"
或 \'
let s3 = "I am \'Peter\'";
let s4 = "I am \"Peter\"";
转义字符: 有些字符不方便直接输入,需要通过一些特殊方式来表示
\n
\\
\'
\"
\t
字符串常用方法:
let s1 = "abc";
console.log(s1.length);
let s2 = "吞吞吐吐大魔王";
console.log(s2.length);
let s1 = "abc";
let s2 = "吞吞吐吐大魔王";
console.log(s1 + s2);
let s3 = "50";
let s4 = 100;
console.log(s3 + s4);
console.log(typeof(s3 + s4));
let s5 = 50;
console.log(s5 + s4);
console.log(typeof(s5 + s4));
基本介绍: true 表示真,false 表示假,并且在 JS 中,boolean 类型可以参与算术运算,true 表示1,false 表示0
示例代码:
console.log(true + 1); // 2
console.log(false - 1); // -1
JS 的布尔类型可以进行算术运算,证明了该语言是弱类型语言
基本介绍: 如果一个变量没有被初始化过,结果就是 undefined
示例代码:
let a;
console.log(a);
undefined 的两种加法运算:
let a;
console.log(a + "吞吞吐吐大魔王");
let a;
console.log(a + 10);
如果参与运算的变量为 undefined,通过上述示例,那么可能会对于接下来的运算结果产生影响,因此,为了防止这种现象,可以让 undefined 的值变为0
let a;
a = a || 0;
console.log(a);
基本介绍: null 表示当前的变量是一个空值
示例代码:
let a = null;
console.log(a);
null 的两种加法运算:
let a = null;
console.log(a + "吞吞吐吐大魔王");
let a = null;
console.log(a + 50);
算术运算符 | 描述 |
---|---|
+ | 加 |
- | 减 |
* | 乘 |
/ | 除 |
% | 取余 |
赋值运算符 | 描述 |
---|---|
= | 赋值 |
+= | 加等 |
-= | 减等 |
*= | 乘等 |
/= | 除等 |
%= | 取余等 |
自增自减运算符 | 描述 |
---|---|
++ | 自增1 |
– | 自减1 |
比较运算符 | 描述 |
---|---|
< | 小于 |
> | 大于 |
<= | 小于等于 |
>= | 大于等于 |
== | 等于 |
!= | 不等于 |
=== | 等于 |
!== | 不等于 |
逻辑运算符 | 描述 |
---|---|
&& | 与 |
|| | 或 |
! | 非 |
位运算符 | 描述 |
---|---|
& | 按位与 |
| | 按位或 |
~ | 按位取反 |
^ | 按位异或 |
移位运算符 | 描述 |
---|---|
<< | 左移 |
>> | 有符号右移(算术右移) |
>>> | 无符号右移(逻辑右移) |
注意: 以上运算符和 Java 中的大部分都相同,下面介绍几处不同点
a&&b
表达式中,a的值为真,则表达式的值就是b的值;如果a的值为假,则表达式的值就是a的值a||b
表达式中,a的值为真,则表达式的值就是a的值;如果a的值为假,则表达式的值就是b的值JS 中的逻辑语句和 Java 中的类似,其中这些语句中的条件表达式的值可以不仅仅是布尔类型,还可以是字符串类型等等。
// 形式1
if (条件) {
语句
}
// 形式2
if (条件) {
语句1
} else {
语句2
}
// 形式3
if (条件1) {
语句1
} else if (条件2) {
语句2
} else if .... {
语句...
} else {
语句N
}
条件 ? 表达式1 : 表达式2
switch (表达式) {
case 值1:
语句1;
break;
case 值2:
语句2;
break;
default:
语句N;
}
while (条件) {
循环体;
}
do {
循环体;
} while(条件);
for (表达式1; 表达式2; 表达式3) {
循环体
}
在C#中,我可以通过base关键字访问基类,在java中,我可以通过super关键字访问它。在delphi中如何做到这一点?假设我有以下代码: type TForm3 = class(TF
在这件事上我已经把头撞到墙上好几次了。所以我希望在正确的方向上得到一点帮助。 我有一张 table ,上面有订单,一张 table 上有火车,一张 table 上有航类,一张 table 上有巴士。每
在 Python 中,假设我有以下代码: class SuperClass(object): def __init__(self, x): self.x = x
我希望这个 subview 扩展到它的父 View 之外,但是父 View 的边框正在切入 subview 。有没有办法防止这种情况? class TheView : UIView { let
我有一个标准的高斯函数,看起来像这样: def gauss_fnc(x, amp, cen, sigma): return amp * np.exp(-(x - cen) ** 2 / (2
例如,我有下一个类,带有有界类型参数: public class ItemContainer { void addItems(List items); } 在另一个带有参数的类中使用: pub
如何将此设置转换为命令? 结果如下: // Manual Compression (see the image above) Compressed Size: 12,647,451 bytes //
请建议在应用继承时如何使用@Wither/@With。 我有一个抽象类Parent和具体的Child。 Child 应该是不可变的。将 @Wither 放在两者上会给我两个错误: 构造函数 Child
关闭。这个问题不符合Stack Overflow guidelines .它目前不接受答案。 这个问题似乎不是关于 a specific programming problem, a softwar
我正在尝试向服务器(虚拟托管)发出 HTTP2 请求,该服务器根据主机 header 值 (SNI) 提供 SSL 证书。 # conn = hyper.HTTP20Connection('h
我有一个应用程序,必须将大约 1300 万行、大约 10 个平均长度的字符串插入到嵌入式 HSQLDB 中。我一直在调整一些东西(批量大小、单线程/多线程、缓存/非缓存表、MVCC 事务、log_si
我想定义一个函数f(x, t::Type)根据 isa(x, t) 是否执行不同的行为.假设我想调用b1(x)如果是,b2(x)除此以外。 我知道我可以像这样在运行时进行动态检查: function
我正在使用 Hyper-V WMI Provider在 Hyper-V 中导入虚拟机,特别是使用 ImportVirtualSystemEx Msvm_VirtualSystemManagementS
这几个星期以来一直困扰着我,我没有结束对它的研究,因为我目前重载并且它让我落后于第一年的 CS (opengl) 大学类(class),这首先让我研究了这个:如何只用一个 for 循环绘制立方体的所有
我正在我的计算机(操作系统:Windows 8)上开发一个 WP8 应用程序。我需要安装一个 VM 才能拥有 linux。同时我需要使用我的 Windows Phone 模拟器。 我下载了 VMWar
我是一名优秀的程序员,十分优秀!