首页 >> js开发 >> jsJS如何定义用字符串拼接的变量js大全
jsJS如何定义用字符串拼接的变量js大全
发布时间: 2021年1月13日 | 浏览:
| 分类:js开发
今天在写js的时候碰到了难题,我又一个页面需要生成很多的变量。但是变量的名称是根据参数的不同而区分的。例如可能需要生成 date_1,date_2,datet_3... (后面的数字是根据参数来的)。 所以我的函数名 应该由 var name = "test_"+num; 生成函数名 但这问题就来了。
1可以使用 window[name] = " " 这种方式来定义变量:1可以使用 window[name] = " " 这种方式来定义变量:所以 var "test_"+num = 100; 这中肯定是错误的。后来问了大哥后才知道。可以使用 window[name] = 100 这种方式来定义变量。看代码
function create_variable(num){
var name = "test_"+num;
//生成函数名
window[name] = 100;
window['name'] = 200;
//注意看中括号里的内容加引号和不加引号的区别
}
create_variable(2);
alert(test_2); // 100;
alert(name); //200;
function create_variable(num){
var name = "test_"+num;
//生成函数名
window[name] = 100;
window['name'] = 200;
//注意看中括号里的内容加引号和不加引号的区别
}
create_variable(2);
alert(test_2); // 100;
alert(name); //200;总结 window用中括号的方式定义 变量时,中括号里的内容应该是字符串。如果是一个变量的话,他就会解析这个变量找到具体的值。他和点语法区别就是这里,点语法后面跟的内容就是要定义的变量名。而不会在解析他是否为变量之类的。例如
var name = "test"
window.name = 200
alert(name); // 200
alert(test);
ReferenceError: test is not defined
var name = "test"
window.name = 200
alert(name); // 200
alert(test);
ReferenceError: test is not defined2用对象的形式2用对象的形式
var test = {};
for(var i = 0; i < 3; i++){
test['test_'+i]='我是字符串'+i;
console.log(test['test_'+i]); //输出:我是字符串0, 我是字符串1, 我是字符串2
}
console.log(test_0); //输出:ReferenceError: test_0 is not defined
console.log(test['test_0']); //输出:我是字符串0
var test = {};
for(var i = 0; i < 3; i++){
test['test_'+i]='我是字符串'+i;
console.log(test['test_'+i]); //输出:我是字符串0, 我是字符串1, 我是字符串2
}
console.log(test_0); //输出:ReferenceError: test_0 is not defined
console.log(test['test_0']); //输出:我是字符串03用数组的形式3用数组的形式
var test = [];
for(var i = 0; i < 3; i++){
test[i]='我是字符串'+i;
console.log(test[i]); //输出:我是字符串0, 我是字符串1, 我是字符串2
}
console.log(test[0]); //输出:我是字符串0
var test = [];
for(var i = 0; i < 3; i++){
test[i]='我是字符串'+i;
console.log(test[i]); //输出:我是字符串0, 我是字符串1, 我是字符串2
}
console.log(test[0]); //输出:我是字符串0以上就是本文的全部内容,希望对大家的学习有所帮助。
1可以使用 window[name] = " " 这种方式来定义变量:1可以使用 window[name] = " " 这种方式来定义变量:所以 var "test_"+num = 100; 这中肯定是错误的。后来问了大哥后才知道。可以使用 window[name] = 100 这种方式来定义变量。看代码
function create_variable(num){
var name = "test_"+num;
//生成函数名
window[name] = 100;
window['name'] = 200;
//注意看中括号里的内容加引号和不加引号的区别
}
create_variable(2);
alert(test_2); // 100;
alert(name); //200;
function create_variable(num){
var name = "test_"+num;
//生成函数名
window[name] = 100;
window['name'] = 200;
//注意看中括号里的内容加引号和不加引号的区别
}
create_variable(2);
alert(test_2); // 100;
alert(name); //200;总结 window用中括号的方式定义 变量时,中括号里的内容应该是字符串。如果是一个变量的话,他就会解析这个变量找到具体的值。他和点语法区别就是这里,点语法后面跟的内容就是要定义的变量名。而不会在解析他是否为变量之类的。例如
var name = "test"
window.name = 200
alert(name); // 200
alert(test);
ReferenceError: test is not defined
var name = "test"
window.name = 200
alert(name); // 200
alert(test);
ReferenceError: test is not defined2用对象的形式2用对象的形式
var test = {};
for(var i = 0; i < 3; i++){
test['test_'+i]='我是字符串'+i;
console.log(test['test_'+i]); //输出:我是字符串0, 我是字符串1, 我是字符串2
}
console.log(test_0); //输出:ReferenceError: test_0 is not defined
console.log(test['test_0']); //输出:我是字符串0
var test = {};
for(var i = 0; i < 3; i++){
test['test_'+i]='我是字符串'+i;
console.log(test['test_'+i]); //输出:我是字符串0, 我是字符串1, 我是字符串2
}
console.log(test_0); //输出:ReferenceError: test_0 is not defined
console.log(test['test_0']); //输出:我是字符串03用数组的形式3用数组的形式
var test = [];
for(var i = 0; i < 3; i++){
test[i]='我是字符串'+i;
console.log(test[i]); //输出:我是字符串0, 我是字符串1, 我是字符串2
}
console.log(test[0]); //输出:我是字符串0
var test = [];
for(var i = 0; i < 3; i++){
test[i]='我是字符串'+i;
console.log(test[i]); //输出:我是字符串0, 我是字符串1, 我是字符串2
}
console.log(test[0]); //输出:我是字符串0以上就是本文的全部内容,希望对大家的学习有所帮助。
相关文章:
- jsJS代码简洁方式之函数方法详解js大全
- js代码从0到1学习JavaScript编写贪吃蛇游戏
- js使用eslint和githooks统一前端风格的技巧js大全
- js小程序实现列表展开收起效果js大全
- jsVue性能优化的方法js大全
- JavaScript如何使用three.js 制作一个三维的推箱子游戏
- jsvue 组件之间事件触发($emit)与event Bus($on)的用法说明js大全
- js代码JavaScript JSON使用原理及注意事项
- jsVue 解决通过this.$refs来获取DOM或者组件报错问题js大全
- jsvue props default Array或是Object的正确写法说明js大全