概述

前端三剑客,html、css、js。

这三种语言基本是前端开发必备的东西,那么你知道这三种语言分别负责的功能是什么吗?

  • html:负责了一个页面的结构
  • css:负责页面的样式
  • JavaScript:负责与用户进行交互

html与css的功能不做赘述,那么,JavaScript是如何负责与用户进行的交互呢?

比如说,我们在网页上输入一个账号,账号的格式要求是必须全部是数字,结果你输入了12343a,这时候网页会给出相应的提示,就是这个意思。

1997年欧洲的计算机协议(ECMA)组织给javascript规定了相关的协议

JavaScript由三部分构成:

  • ECMAScirpt(规范了基本的语法)
  • BOM (浏览器对象模型)
  • DOM (文档对象模型)

接下来我们来介绍一下JavaScript特点:

  • 安全性(javascript的代码不能直接访问硬盘的内容)
  • 跨平台(很简单,只要有浏览器,就可以运行js)

最后来说一下javascript与java之间区别 :

  • javascript是属于网景公司产品, java是sun公司的产品
  • javascript是基于对象的语言,java是面向对象的语言

    基于对象:不具备面向对象的三大特征,但是有对象
  • javascript是解释型语言;java是解释、编译型语言
  • javascript是弱类型语言, java 是强类型语言

    java中声明变量的时候必须要明确该变量的数据类型

    javascript声明变量不需要明确是何种数据类型, 任何的变量都是使用一个关键字var去声明的

在了解了JavaScript的一些基本内容之后,我们就要进入JavaScript的编写工序了!

如何编写JavaScript的代码

1.首先说一下JavaScript中常用的函数

  • alert(”显示的内容”) ——弹出框
  • document.write(”数据”)——-向页面输出数据
//1. 可以使用 <script> 标签体内进行编写,代码如下
<script type="text/javascript">
alert("666");
</script>

这个时候浏览html页面的时候就会弹出窗口,并显示666。

//2. 可以引入外部的javascript文件
格式:
<script src="1.js" type="text/javascript"></script>
注意:
1.<script>是有开始标签与结束标签的,千万不要在一个标签中结束了
2.如果<script>已经用于引入了js文件,那么该<script>标签体就不能再写js代码了

2.注释

//注释的内容 单行注释 /* 注释的内容*/ 多行注释

3.JavaScript的变量声明

格式:var 变量名 = 数据

<script type="text/javascript">
var a = 10;
document.write("a="+a+"<br/>");
</script>

声明变量要注意的事项:

1. 在javascript中声明变量是使用var关键字声明的,javascript中的变量可以存储任意的数据类型数据

2. javascript中变量数据类型是根据存储的值决定的,可以随时更改存储数据的类型

3. 定义了多个同名的变量是,后定义的同名变量是覆盖前面定义的同名变量

4. 声明变量的时候可以省略var关键字,但是不建议省略

JavaScript的数据类型

typeof: 查看变量的数据类型。

使用格式:

        typeof 变量名

javascript的数据类型:

number 小数与整数

string 字符串 注意: javascript中没有字符的概念,只有字符串,字符串可以写在单引号或双引号中。

boolean 布尔数据类型,

undefined  undefined代表该变量没有定义

typeof使用方法如下:

var a = 10;
document.write("a的数据类型是"+(typeof a)+"<br/>");

将字符串转换成数字

用到的方法有:

  • parseInt()—-将一个字符串转换成整数。

    如果接收的字符串含有非数字字符,那么parseInt方法会从字符串的首个字符开始寻找,一直找到非数字字符为止,然后就使用前面的数字字符转换成数字
var a = "a123";
var b = parseInt(a);
document.write("字符串a转换后的数字是:"+b+"<br/>"); var a = "123abc123";
var b = parseInt(a);
document.write("字符串a转换后的数字是:"+b+"<br/>"); var a = "012";
var b = parseInt(a);
document.write("字符串a转换后的数字是:"+b+"<br/>");

输出结果如下:

字符串a转换后的数字是:NaN not a number(不是一个数字)
字符串a转换后的数字是:123
字符串a转换后的数字是:12 如果首位是0,那么就先去掉0在进行转换
字符串a转换后的数字是:18 如果一个字符串是以0x开头,那么会把字符串中的内容当成十六进行的数据处理
  • parseFloat()—–将一个字符串转换成浮点型数字。

    代码如下:
<script type="text/javascript">
var a = 3.14;
var b = parseFloat(a);
document.write("结果是:" + b);
</script>

这里输出的结果是3,14

根据上面的这些例子,我们可以知道,并不是所有的字符串都可以转换成数字,那么,我们应该如何判断一个字符串是否能够转换成数字呢?

JavaScript提供了一个IsNaN(is not a number)的方法帮助我们判断字符串是否可以转换成一个数字。千万注意的是,这个方法和以往的方法有做不同,这个方法中,不是一个数字返回true,是一个数字返回false。(有点反人类。。)

4.运算符

学到这一步,其实在其他语言(c或者java)中这部分内容都要介绍烂了,我只写一些比较重要的内容。

  • 一个数值加减true,其实是加减的0。而在java中,数字不能与布尔值相加减
  • 如果两个整数相除不能整除的时候,数值为小数
  • 比较运算符:字符串和字符串也能够比较、字符串能够与数字进行比较(先将字符串转换成数字再进行比较)

    比较规则如下:
/*
字符串与字符串的比较规则是: 情况1: 能找到对应位置上的不同字符,那么就比较第一个不同字符的大小。 情况2: 不能找到对应位置上的不同字符,这时候比较的是两个字符串的长度。 */
<script type="text/javascript">
document.write("10字符串和3的字符串比较谁的大?"+("19">"18888"+"<br/>"));
</script>

所以,上述代码输出的结果应该是true。

  • 逻辑运算符:没有单与(&)单或(|),只有短路与(&&)和短路或(||)
  • 三目运算符:布尔表达式?值1:值2

5.控制流程语句

  1. if语句

    特殊之处:

    在javascript中的if语句条件不单止可以写布尔表达式,还可以写任何的数据。

    number  非0为true, 0为false.
    string 内容不空是true, 内容空的时候是false。
    undefined:false
    NaN: false
  2. 选择语句

    特殊之处:在javascript中case后面可以跟常量与变量,还可以跟表达式

    代码如下:
var option = "A";
var a = "A";
var score = 66;
switch(option){
case a:
document.writeln("90分");
break;
case "B":
document.writeln("80分");
break;
case score>60?"C":"B" :
document.writeln("60分");
default:
break;
}

JavaScript学习总结(一)的更多相关文章

  1. JavaScript学习(一) —— 环境搭建与JavaScript初探

    1.开发环境搭建 本系列教程的开发工具,我们采用HBuilder. 可以去网上下载最新的版本,然后解压一下就能直接用了.学习JavaScript,环境搭建是非常简单的,或者说,只要你有一个浏览器,一个 ...

  2. Web编程基础--HTML、CSS、JavaScript 学习之课程作业“仿360极速浏览器新标签页”

    Web编程基础--HTML.CSS.JavaScript 学习之课程作业"仿360极速浏览器新标签页" 背景: 作为一个中专网站建设出身,之前总是做静态的HTML+CSS+DIV没 ...

  3. JavaScript学习(3):函数式编程

    在这篇文章里,我们讨论函数式编程. 什么是函数式编程?根据百度百科的描述,“函数式编程是种编程典范,它将电脑运算视为函数的计算.函数编程语言最重要的基础是 λ 演算(lambda calculus). ...

  4. JavaScript学习(2):对象、集合以及错误处理

    在这篇文章里,我们讨论一下JavaScript中的对象.数组以及错误处理. 1. 对象 对象是JavaScript中的一种基本类型,它内部包含一些属性,我们可以对这些属性进行增删操作. 1.1 属性 ...

  5. JavaScript学习13 JavaScript中的继承

    JavaScript学习13 JavaScript中的继承 继承第一种方式:对象冒充 <script type="text/javascript"> //继承第一种方式 ...

  6. JavaScript学习12 JS中定义对象的几种方式

    JavaScript学习12 JS中定义对象的几种方式 JavaScript中没有类的概念,只有对象. 在JavaScript中定义对象可以采用以下几种方式: 1.基于已有对象扩充其属性和方法 2.工 ...

  7. JavaScript学习11 数组排序实例

    JavaScript学习11 数组排序实例 数组声明 关于数组对象的声明,以前说过:http://www.cnblogs.com/mengdd/p/3680649.html 数组声明的一种方式: va ...

  8. JavaScript学习10 JS数据类型、强制类型转换和对象属性

    JavaScript学习10 JS数据类型.强制类型转换和对象属性 JavaScript数据类型 JavaScript中有五种原始数据类型:Undefined.Null.Boolean.Number以 ...

  9. JavaScript学习09 函数本质及Function对象深入探索

    JavaScript学习09 函数本质及Function对象深入探索 在JavaScript中,函数function就是对象. JS中没有方法重载 在JavaScript中,没有方法(函数)重载的概念 ...

  10. JavaScript学习08 Cookie对象

    JavaScript学习08 Cookie对象 JavaScript Cookie Cookie对象: Cookie是一种以文件的形式保存在客户端硬盘的Cookies文件夹中的用户数据信息(Cooki ...

随机推荐

  1. S7-200 smart 网线下载与调试配置

    打开 step microwin 7 smart 软件. 连接PLC 打开 通讯模块 我把电脑的改成了如下 我编写的简单的程序 通过外部一个开关 实现输出的一个 IO 的接通与断开 下载完成程序以后 ...

  2. UVA - 10891 Game of Sum (区间dp)

    题意:AB两人分别拿一列n个数字,只能从左端或右端拿,不能同时从两端拿,可拿一个或多个,问在两人尽可能多拿的情况下,A最多比B多拿多少. 分析: 1.枚举先手拿的分界线,要么从左端拿,要么从右端拿,比 ...

  3. MSDN原版系统镜像ISO下载站

    官网 网址1:http://www.imsdn.cn/ Windows 10 最新版本 1909 正式版 ISO 镜像下载 (微软 MSDN / VL 官方原版系统) 网址2:https://www. ...

  4. 百度杀毒停止下载,个人PC杀毒软件真的走到尽头了吗?

    在时代浪潮的席卷下,不适应的服务和产品终将被淘汰.诺基亚如此,杀毒软件亦是如此.就在近日,久久沉寂的杀毒软件市场被投下一颗重磅炸弹--百度杀毒软件官网PC端不再提供下载,但手机端依然提供下载和杀毒服务 ...

  5. tomcat中war 和 war exploded的区别

    war和war exploded的区别(转载) 在使用idea开发项目的时候,部署Tomcat的时候通常会出现下边的情况: 是选择war还是war exploded这里首先看一下他们两个的区别: wa ...

  6. CSS屏幕适配尺寸样式

    /* 大屏幕 :大于等于1200px*/@media (min-width: 1200px) { ... } /*默认*/@media (min-width: 980px){...} /* 平板电脑和 ...

  7. bzoj 4008、4011、1499

    全是扒题解,,,太弱了... 不乱BB了. 4008 #include <bits/stdc++.h> #define LL long long #define lowbit(x) x&a ...

  8. 13 装备的添加和移除(Unity3D)

    本案例主要实现功能如下:1.创建UI界面,包含两个装备栏,四个武器选择栏以及显示人物的属性的文本框2.每一个装备都有自己的属性(AD/AP/AR/MP)3.人物也有自己的基础属性(AD/AP/AR/M ...

  9. zabbix 日志

    /var/log/zabbix/ tail -f /var/log/zabbix/zabbix_server.log tail -f /var/log/zabbix/zabbix_agentd.log

  10. 解决TeamViewer提示商业用途

    安装此插件 提取码:i8o3