首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

Javascript"变量变量":如何根据另一个变量分配变量?

在JavaScript中,可以使用变量变量来根据另一个变量分配变量。这可以通过两种方法实现:

  1. 使用window对象:
代码语言:javascript
复制
var variableName = "variable1";
var variable1 = "value1";
var variable2 = "value2";

var value = window[variableName];
console.log(value); // 输出 "value1"
  1. 使用eval函数:
代码语言:javascript
复制
var variableName = "variable1";
var variable1 = "value1";
var variable2 = "value2";

var value = eval(variableName);
console.log(value); // 输出 "value1"

在这两种方法中,window对象方法更为推荐,因为eval函数可能会带来安全风险。

在实际应用中,如果需要根据变量名来分配变量,可以考虑使用对象来存储这些变量,而不是直接使用多个变量。例如:

代码语言:javascript
复制
var variables = {
  variable1: "value1",
  variable2: "value2"
};

var variableName = "variable1";
var value = variables[variableName];
console.log(value); // 输出 "value1"

这种方法更加安全、简洁,且易于维护。

页面内容是否对你有帮助?
有帮助
没帮助

相关·内容

JavaScriptJavaScript 变量 ① ( JavaScript 变量概念 | 变量声明 | 变量类型 | 变量初始化 | ES6 简介 )

一、JavaScript 变量 1、变量概念 JavaScript 变量 是用于 存储数据 的 容器 , 通过 变量名称 , 可以 获取 / 修改 变量 中的数据 ; 变量 的 本质 是 存放数据 的...一块内存空间 ; 在 JavaScript 中,使用 var / let / const 关键字来声明变量 , 每个变量都有一个 变量名 和 一个 变量值 ; 2、变量声明 JavaScript 变量声明...是传统方式 , 任何时候都可以使用 ; let 和 const 声明变量的关键字 是在 ES6 中引入的 , ES6 全称 ECMAScript 2015 , 是JavaScript语言的下一代标准...是一种动态类型语言,不需要在声明变量时指定其类型 ; JavaScrip 变量 的 数据类型 由 设置给变量的值决定 , 变量类型 可以在程序执行过程中更改 ; JavaScript 数据类型 : Number...name; 二、JavaScript 变量示例 1、代码示例 <!

53410
  • JS–JavaScript变量详解(全局变量、局部变量)

    JavaScript变量 JavaScript使用var关键字声明变量。声明变量的5种常规用法如下: var a; //声明单个变量。...var关键字与变量名之间以空格分隔 var b, c; //声明多个变量变量之间以逗号分隔 var d = 1; //声明并初始化变量。...以逗号分隔多个变量 var e = f = 3; //声明并初始化多个变量,且定义变量的值相同 JavaScript也支持不使用var命令,直接使用未声明的变量。...变量的命名规则如下:* 首字符必须是大写或小写的字母、下划线(_)或美元符($),后续的字符可以是字母、数字、下划线或美元符。 变量名称不能是JavaScript关键字或保留字。...根据可见性,变量可以分为全局变量和局部变量(或称私有变量) 全局变量在整个页面中可见,并在页面任何位置被允许访问。 局部变量只能在指定函数内可见,函数外面是不可见的,也不允许访问。

    8.7K10

    JavaScript变量

    变量 一小块存储数据的内存空间。...Java中变量 定义方式: int a=10; 语法: 数据类型 变量名=初始值; Java中定义变量时需要声明所定义变量的类型,所以在Java中变量是强类型语言,即在开辟内存变量存储空间时,定义了内存将来存储的数据类型...JavaScript变量 定义方式: var a=10; 语法: var 变量名=初始值; 在JavaScript中定义变量时不需要声明该变量的数据类型,所以变量JavaScript中是弱类型语言,...如何获取JavaScript变量的数据类型 要想获取到JavaScript变量的数据类型,需要用到typeof 运算符。...注意: 无论在Java中还是JavaScript中,变量名的命名规则都需要遵循驼峰命名法,变量名要有意义,看到这个名字你可以想到它的作用;一般是字母开头、$、_开头,一般jQuery中使用$开头。

    30620

    JavaScript——变量

    变量 变量就是一个装东西的盒子。 变量是用于存放数据的 容器,我们通过 变量名获取数据,甚至数据可以修改。 本质:变量是程序在内存中申请的一块用来存放数据的空间。...变量的使用 声明变量 // 声明变量 var age;//声明一个名称为age的变量 var是一个JS关键字,用来声明变量(variable变量的意思)。...使用该关键字声明变量后,计算机会自动为变量分配内存空间,不需要程序员管。 age是程序员定义的变量名,我们要通过变量名来访问内存中分配的空间。...变量的初始化 var age = 18;//声明变量同时赋值为18 声明一个变量并赋值,我们称之为变量的初始化。...声明变量并赋值我们称之为变量的初始化。 变量名要尽量规范,见名知意——驼峰命名法

    52220

    javascript -- 变量

    ECMAScript的变量是松散类型的,所谓松散类型就是(变量)可以用来保存任意类型的数据。换句话说每个变量仅仅是在特定的时间内保存值的占位符而已。 所谓特定的时间就是变量的生命周期。...(var定义的变量将称为该作用域中的局部变量 即全局下就是全局变量,函数内就是局部变量) 全局作用域:在全局下有效(全局定义或函数内未定义只赋值的变量),即window下都可以使用。...函数作用域:只在函数体内有效,函数运行完函数、变量立即销毁,这也是无法在外面引用函数内的变量的原因。...未初始化的会保存一个undefined console.log(message);// undefined 函数退出后,变量销毁. function test(){ var msg='hi'; // 局部变量...} test(); console.log(msg);// 错误 函数体内未定义只赋值的变量是全局变量: function test(){ msg='hi';// 全局变量 不太推荐 因为在局部定义全局变量

    67410

    JavaScript变量

    1、 什么是变量 白话:变量就是一个装东西的盒子。 通俗:变量是用于存放数据的容器。 我们通过 变量名 获取数据,甚至数据可以修改。 ?...3、变量的使用 分为两步: 变量的声明 变量的赋值 3.1 声明变量 // 声明变量   var age; // 声明一个 名称为age 的变量     var 是一个 JS关键字...使用该关键字声明变量后,计算机会自动为变量分配内存空间,不需要程序员管 age 是程序员定义的变量名,我们要通过变量名来访问内存中分配的空间 3.2 赋值 age = 10; // 给 age...// 声明变量同时赋值为 18 声明一个变量并赋值, 我们称之为变量的初始化。...3.4 变量语法扩展 更新变量 一个变量被重新复赋值后,它原有的值就会被覆盖,变量值将以最后一次赋的值为准。

    67130

    JavaScript 变量

    # JavaScript 变量 什么是变量 变量在内存中的存储 变量的使用 声明变量 赋值 变量的初始化 案例 变量的语法扩展 更新变量 同时声明多个变量 声明变量特殊情况 变量的命名规范 交换变量...# 什么是变量 白话:变量就是一个装东西的盒子。...# 变量的使用 变量在使用时分为两步: 声明变量 赋值 # 声明变量 //声明变量 var age; // 声明一个 名称为age 的变量 var是一个JS关键字,用来声明变量( variable...使用该关键字声明变量后,计算机会自动为变量分配内存空间,不需要程序员管 age是程序员定义的变量名,我们要通过变量名来访问内存中分配的空间 # 赋值 age = 10; // 给 age 这个变量赋值为...10 = 用来把右边的值赋给左边的变量空间中 此处代表赋值的意思 变量值是程序员保存到变量空间里的值 # 变量的初始化 var age = 18; // 声明变量同时赋值为 18 声明一个变量并赋值,

    44220

    JavaScriptJavaScript 变量 ② ( JavaScript 变量语法扩展 | 同时声明多个变量 | 只声明变量不赋值 | 不声明变量不赋值 | 不声明变量直接进行赋值 )

    一、JavaScript 变量语法扩展 1、同时声明多个变量JavaScript 中可以 使用一个 var 关键字 , 同时声明多个 变量 , 多个变量之间使用 逗号 " , " 隔开 ; 这种变量定义方法..., 只适用于 var 关键字 , let 和 const 关键字不能使用 ; 这种定义变量的方式已经过时 , 不推荐在现代 JavaScript 代码中使用 , 因为它可能会导致混淆和错误 ; 代码示例... 展示效果 : 2、只声明变量不赋值 在 JavaScript 中 , 使用 var 关键字 在 函数作用域或全局作用域..." undefined " ; 3、不声明变量不赋值 在 JavaScript 中 , 不声明变量 , 不对该变量进行赋值 , 直接使用该变量 , 编译时不报错 , 执行时会报错 : demo.html...在 JavaScript 中 , 不声明变量 直接进行赋值 , 可以直接使用该变量 ; 如果 不显式声明变量 , 就直接进行 赋值使用 , 那么 这个变量会自动成为全局变量 , 在严格模式下直接报错

    9910

    JavaScript 变量提升

    初始化阶段, 这一阶段分配了内存并在作用域中让内存与变量建立了一个绑定,变量会被自动初始化为 undefined 。 赋值阶段,这一阶段为已初始化的变量分配具体的一个值。...var 变量的生命周期 稍微熟悉下变量的三大生命周期阶段,现在让我们用它们来描述引擎是如何处理 var 变量的。 ?...假设一个场景,当 JavaScript 遇到了一个函数作用域,其中包含了 var variable 的语句,则在任何语句执行之前,这个变量就已经通过了声明阶段和初始化阶段(对于 var 来说,该两阶段不存在任何间隙...如果这时尝试访问 variabl ,JavaScript 将会抛出 ReferenceError: variable is not defined ,因为这个变量的状态依然是未初始化的。...如果 JavaScript 遇到了 let variable = 'some value' ,那么变量会在这一个条语句中完成初始化和赋值阶段。

    88230

    JavaScript变量污染

    变量类型 JavaScript 是弱类型语言,对于变量类型的规范比较松散。具体表现如下: 变量的类型分类不严谨、不明确,带来使用的随意性。 声明变量时,不要求指定类型。...使用过程不严格,可以根据需要自动转换变量类型。 变量的转换和类型检查没有一套统一、规范的方法,导致开发效率低下。 由此带来的优缺点如下: 优点:使用灵活,简化了代码编写。...JavaScript变量污染 定义全局变量有 3 种方式: 在任何函数体外直接使用 var 语句声明。var f = 'value1'; 直接添加属性到全局对象上。...window.f = 'value'; 直接使用未经声明的变量,以这种方式定义的全局变量被称为隐式的全局变量。f = 'value'; 全局变量在全局作用域内都是可见的,因此具有污染性。...function(){ //具体方法 //执行代码 } }; window.MyAPP; //对外开放应用程序接口 })(window) 在 JavaScript

    20920

    【MATLAB】变量 ( 变量引入 | 变量类型 )

    文章目录 一、变量引入 ( ans 默认变量 ) 二、变量类型 一、变量引入 ( ans 默认变量 ) ---- 使用 matlab 代码编写如下公式时 , 公式层级很多 , 很复杂 , 需要很多括号进行优先级限制...中 , 每一步的计算结果自动存储在 ans 变量中 , 如果要分步进行计算 , 可使直接调用 ans 变量当做前一步骤的输出结果 ; 分步计算的 matlab 代码 : (1 + 2 + 3 + 4)...---- 在 matlab 中变量不需要声明 , 可以直接使用 , 变量的类型根据赋值的类型确定 , 变量类型是自动判定的 ; 变量类型 : 如果声明一个变量不为其赋值 , 该变量默认为 double...类型 ; 将 10 数值赋值给 a 变量 , a 变量的类型就是一个整型 ; a = 10 运行该代码 , 结果如下 : >> Untitled a = 10 >> 双击 " 工作区..." 中的 " a " 变量 , 可以在 " 变量 " 界面中看到 a 变量的类型 , 是 1 \times 1 的 double 类型 ; 在命令行中使用 who 和 whos 命令 , 可以得到当前工作区变量的简略和详细信息

    5.6K20

    javascript---变量

    var a = 1;//同上,只是声明了a } 感觉js的方法中的参数,在使用后可以声明,但是不能定义(赋值); 解析:Scoping(作用域),当解析器读到alert语句的时候,它发现有一个变量声明和赋值...a){//1 var a = 2; } alert(a);//2 } 在方法中声明了变量,则应用方法中的,不会使用全局变量; 结论:(网上的) 1.语言定义的命名:比如 this...或者 arguments,它们在所有作用域内都有效且优先级最高,所以在任何地方你都不能把变量命名为 this 之类的,这样是没有意义的 2.形式参数:函数定义时声明的形式参数会作为变量被 hoisting...当然你可以在执行函数的时候把外部变量传进来,但是传进来之后就是本地的了 3.函数声明:函数体内部还可以声明函数,不过它们也都是本地的了 4.变量声明:这个优先级其实还是最低的,不过它们也都是最常用的...好比在我们写java代码的时候,在方法中,我们必须声明后在使用,但是在在类中,声明并不是有顺序,当然赋值也一样,然而在javascript中,在方法中都已经实现了这一点, 所以在使用变量时,最好在方法顶端就声明

    42830

    JavaScript全局变量与局部变量

    局部 JavaScript 变量JavaScript 函数内部声明的变量(使用 var)是局部变量,所以只能在函数内部访问它。(该变量的作用域是局部的)。...您可以在不同的函数中使用名称相同的局部变量,因为只有声明过该变量的函数才能识别出该变量。 只要函数运行完毕,本地变量就会被删除。...---- 全局 JavaScript 变量 在函数外声明的变量是全局变量,网页上的所有脚本和函数都能访问它。...---- JavaScript 变量的生存期 JavaScript 变量的生命期从它们被声明的时间开始。 局部变量会在函数运行以后被删除。 全局变量会在页面关闭后被删除。...---- 向未声明的 JavaScript 变量分配值 如果您把值赋给尚未声明的变量,该变量将被自动作为全局变量声明。

    70810

    Javascript全局变量和局部变量

    Javascript全局变量和局部变量 先看一段代码: var a =1; function test(){ alert(a); var a = 2...Javascript在执行前会对整个脚本文件的**定义部分(注意,并不包括赋值部分)**做完整分析,所以在函数test()执行前,函数体中的变量a就被指向内部的局部变量.而不是指向外部的全局变量....但是,一旦在函数内重新声明了与全局变量同名的变量,不管是否赋值了,那么这个函数内的变量就是局部变量了。...且Javascript在执行前会只是对整个脚本文件的**定义部分(注意,并不包括赋值部分)**做完整分析,并不会解析赋值,所以在语句执行时,仍是自上而下,那么在函数体内,a已经被解析为局部变量,且没有给...这个a并不是全局变量,这是因为在function scope里已经声明了(函数体倒数第4行)一个重名的局部变量, //所以全局变量a被覆盖了,这说明了Javascript

    47630
    领券