当前位置: 首页 > news >正文

JavaScript对象和函数——JavaScript筑基

JavaScript对象拥有属性和方法的数据。

JavaScript对象

  • 生活中的对象、属性和方法
  • JavaScript对象
  • 对象的定义
  • 对象属性
  • 访问对象的属性
  • 对象的方法
  • JavaScript函数语法
  • 调用带参数的函数
  • 局部JavaScript变量
  • JavaScript变量的生存期


生活中的对象、属性和方法

生活中,一辆汽车就是一个对象。
对象拥有属性,例如重量、颜色、尺寸等等。方法则有启动、加速、减速等等。
在这里插入图片描述

所有汽车拥有这些属性、虽然具体属性不同。
所有汽车都拥有这些方法,方法具体实现、执行方式不一样。


JavaScript对象

在JavaScript中,几乎所有事物都是对象

在 JavaScript 中,对象是非常重要的,当你理解了对象,就可以了解 JavaScript 。

下面的代码给变量car,设置初始值:

var car = "Fiat";

对象是一个变量,对象可以包含多个数值,多个变量,每一个数值以name:value形式存在。

var car = {name:"Fiat", model:500, color:"white"}; 

通过上述代码,3个数值被赋予给了car变量。

JavaScript 对象是变量的容器。


对象的定义

可以利用字符定义创建JavaScript对象:

var person = {firstName:"John", lastName:"Doe", age:50, eyeColor:"blue"};

定义JavaScript对象可以跨越多行,空格跟换行都不是必须的:

var person = {
    firstName:"John",
    lastName:"Doe",
    age:50,
    eyeColor:"blue"
}; 

对象属性

可以说JavaScript对象是变量的容器。但一般意义上都认为JavaScript对象是键值对的容器

键值对通常写法name:value,键值对之间利用冒号分隔。

键值对在JavaScript对象称之为对象的属性。

JavaScript 对象是属性变量的容器。

对象的键值对写法类似:

  • PHP的关联数组:$scoreArray 是变量的名称、[‘KeyName’] 是元素的索引键。
<?php
  $scoreArray = array(
    'Chandler' => 50, 
    'Monica' => 80, 
    'Ross' => 95
  ); 
?>
  • Python 中的字典:
users = ['user1','user2']
passwds = ['123','456']
print(zip(users,passwds))
print(list(zip(users,passwds)))
print(dict(zip(users,passwds)))
  • Java的哈希映射

访问对象的属性

可以通过两种方式访问对象属性:

person.lastName;
person["lastName"]; 

对象的方法

对象的方法定义了一个函数,并且作为对象的属性存储。

对象方法都是通过添加()调用作为一个函数。

name = person.fullName();

如果你要访问 person 对象的 fullName 属性,它将作为一个定义函数的字符串返回:

name = person.fullName;

JavaScript 对象是属性和方法的容器。


JavaScript函数语法

调用这个函数,执行相应的函数内代码。

function name() {
}

JavaScript 对大小写敏感。关键词 function 必须是小写的,并且必须以与函数名称相同的大小写来调用函数。

***在这里插入代码片

调用带参数的函数

调用带参数的函数,可以向其传递数值,称之为参数。
这些参数可以用在函数中;

myFunction(argument1,argument2)

变量和参数必须一致顺序出现,第一个变量就是


<p>点击这个按钮,来调用带参数的函数。</p>
<button onclick="myFunction('Harry Potter','Wizard')">点击这里</button>
<script>
function myFunction(name,job){
    alert("Welcome " + name + ", the " + job);
}
</script>

上面的函数在按钮被点击时会提示 “Welcome Harry Potter, the Wizard”。

函数很灵活,您可以使用不同的参数来调用该函数,这样就会给出不同的消息:

<!DOCTYPE html>
<html>
<head> 
<meta charset="utf-8"> 
<title>test</title> 
</head>
<body>
<p>请点击其中的一个按钮,来调用带参数的函数。</p>
<button onclick="myFunction('Harry Potter','Wizard')">点击这里</button>
<button onclick="myFunction('Bob','Builder')">点击这里</button>
<script>
function myFunction(name,job)
{
	alert("Welcome " + name + ", the " + job);
}
</script>
</body>
</html>

局部JavaScript变量

在 JavaScript 函数内部声明的变量(使用 var)是局部变量,所以只能在函数内部访问它。(该变量的作用域是局部的)。

您可以在不同的函数中使用名称相同的局部变量,因为只有声明过该变量的函数才能识别出该变量。

只要函数运行完毕,本地变量就会被删除。


JavaScript变量的生存期

JavaScript 变量的生命期从它们被声明的时间开始。

局部变量会在函数运行以后被删除。

全局变量会在页面关闭后被删除。

var var1 = 1; // 不可配置全局属性
var2 = 2; // 没有使用 var 声明,可配置全局属性

console.log(this.var1); // 1
console.log(window.var1); // 1
console.log(window.var2); // 2

delete var1; // false 无法删除
console.log(var1); //1

delete var2; 
console.log(delete var2); // true
console.log(var2); // 已经删除 报错变量未定义

相关文章:

  • Java知识记录
  • 排列组合总结
  • IIC协议详解
  • javaIO流05:FileReader和Filewriter
  • 【PTHREAD】线程创建
  • s19.基于 Kubernetes v1.25.0(kubeadm) 和 Docker 部署高可用集群(一)
  • 力扣记录:Hot100(4)——75-101
  • 数据结构之——OJ题环形队列实现详解
  • 基于樽海鞘群算法的线性规划求解matlab程序
  • qt自定义控件之TextEdit
  • 深度估计 双目深度估计+单目深度估计 ONNX运行程序
  • Express 路由
  • 2022蓝帽杯初赛电子取证
  • 数据结构与算法复习:第三十六弹
  • CSS - 响应式布局(一)媒体查询
  • 77. Combinations
  • const let
  • Java,console输出实时的转向GUI textbox
  • JavaScript HTML DOM
  • java中具有继承关系的类及其对象初始化顺序
  • linux安装openssl、swoole等扩展的具体步骤
  • python学习笔记 - ThreadLocal
  • spring security oauth2 password授权模式
  • windows下mongoDB的环境配置
  • Zepto.js源码学习之二
  • 分享一份非常强势的Android面试题
  • 基于MaxCompute打造轻盈的人人车移动端数据平台
  • 技术攻略】php设计模式(一):简介及创建型模式
  • 排序(1):冒泡排序
  • 学习ES6 变量的解构赋值
  • 优秀架构师必须掌握的架构思维
  • media数据库操作,可以进行增删改查,实现回收站,隐私照片功能 SharedPreferences存储地址:
  • 3月7日云栖精选夜读 | RSA 2019安全大会:企业资产管理成行业新风向标,云上安全占绝对优势 ...
  • 从如何停掉 Promise 链说起
  • 昨天1024程序员节,我故意写了个死循环~
  • ​Base64转换成图片,android studio build乱码,找不到okio.ByteString接腾讯人脸识别
  • ​第20课 在Android Native开发中加入新的C++类
  • #Z0458. 树的中心2
  • #周末课堂# 【Linux + JVM + Mysql高级性能优化班】(火热报名中~~~)
  • ()、[]、{}、(())、[[]]命令替换
  • (2.2w字)前端单元测试之Jest详解篇
  • (51单片机)第五章-A/D和D/A工作原理-A/D
  • (附源码)springboot电竞专题网站 毕业设计 641314
  • (十五)devops持续集成开发——jenkins流水线构建策略配置及触发器的使用
  • (原創) 如何安裝Linux版本的Quartus II? (SOC) (Quartus II) (Linux) (RedHat) (VirtualBox)
  • (转)memcache、redis缓存
  • (转)人的集合论——移山之道
  • ***通过什么方式***网吧
  • .net用HTML开发怎么调试,如何使用ASP.NET MVC在调试中查看控制器生成的html?
  • .pyc文件是什么?
  • @cacheable 是否缓存成功_让我们来学习学习SpringCache分布式缓存,为什么用?
  • []AT 指令 收发短信和GPRS上网 SIM508/548
  • [1]-基于图搜索的路径规划基础
  • [20150629]简单的加密连接.txt
  • [20170705]lsnrctl status LISTENER_SCAN1