javascript - 文本 var 到 json 数组
问题描述
我正在尝试使用 prebid 配置标题出价。我正在使用 php + mysql 从数据库中加载我想要的广告,并使用来自 php 的数据在 javascript 中创建一个文本变量。
当我必须创建变量“adUnits”时,问题就来了。如果我手动创建它,直接编写它可以正常工作,但使用 javascript 创建相同的内容我不明白它的工作原理。
这是有效的代码
var adUnits = [{
code: '/123/468x60',
mediaTypes: {
banner: {
sizes: [
[468, 60]
]
}
},
bids: [{
bidder: 'adserver',
params: {
networkId: 1234
}
}]
}, {
code: '/123/336x280',
mediaTypes: {
banner: {
sizes: [
[336, 280],
[300, 250]
]
}
},
bids: [{
bidder: 'adserver',
params: {
networkId: 1234
}
}]
}, {
code: '/123/300x600',
mediaTypes: {
banner: {
sizes: [
[300, 600],
[300, 250]
]
}
},
bids: [{
bidder: 'adserver',
params: {
networkId: 1234
}
}]
}];
这是不起作用的代码
var arrayadsname = adsname.split('#');//content of arrayadsname => /123/468x60#/123/336x280#/123/300x600
var arrayadssize = adssize.split('#');//content of arrayadssize => 468x60#336,280|300,250#300,600|300,250
var arraysize = '';
var ad = '';
var adUnits = [];
var preadUnits = '';
for (var i = 0; i < arrayadsname.length; i++) {
var arraysizeparts = arrayadssize[i].split('|');
for (var j = 0; j < arraysizeparts.length; j++) {
if (j == 0){
arraysize = '[' + arraysizeparts[j] + ']';
}else{
arraysize = arraysize + ',' + '[' + arraysizeparts[j] + ']';
}
}
ad = '{code: \'' + arrayadsname[i] + '\', mediaTypes: {banner: {sizes: ' + '[' + arraysize + ']' + '}}, bids: [{bidder: \'adserver\', params: {networkId: 1234}}]}';
if (i == 0) preadUnits = ad;
else preadUnits = preadUnits + ',' + ad;
}
//Result of ad => {code: '/123/468x60', mediaTypes: {banner: {sizes: [[468,60]]}}, bids: [{bidder: 'adserver', params: {networkId: 1234}}]},{code: '/123/336x280', mediaTypes: {banner: {sizes: [[336,280],[300,250]]}}, bids: [{bidder: 'adserver', params: {networkId: 1234}}]},{code: '/123/300x600', mediaTypes: {banner: {sizes: [[300,600],[300,250]]}}, bids: [{bidder: 'adserver', params: {networkId: 1234}}]}
adUnits = "[" + JSON.stringify(preadUnits) + "]";
我已经尝试了所有可能的组合声明变量 asUnits,如对象、数组、文本,并使用 JSON.stringify,JSON.parse 也声明“arraysize”,如数组并解析它。我不知道是哪个问题。
我在控制台中看到这个错误:“被调用者:[异常:TypeError:'调用者','被调用者'和'参数'属性可能无法在严格模式函数或参数对象上访问以在 Arguments.invokeGetter 调用它们”
提前致谢
解决方案
sizes
首先为中的每个项目构造一个数组adssize
- 例如,'300,600|300,250'
变成[[300, 600], [300, 250]]
。然后,您可以adUnits
通过映射代码(由 分割#
)并访问sizes
刚刚构造的数组上的适当索引来创建对象:
const codes = '/123/468x60#/123/336x280#/123/300x600'.split('#');
const sizes = '468x60#336,280|300,250#300,600|300,250'
.split('#')
.map(
// str is something like: '300,600|300,250'
str => str.split('|').map(
// substr is something like: '300,600'
substr => substr.split(/[,x]/).map(Number)
)
);
const adUnits = codes.map((code, i) => ({
code,
mediaTypes: {
banner: {
sizes: sizes[i]
}
},
bids: [{
bidder: 'adserver',
params: {
networkId: 1234
}
}]
}));
console.log(adUnits);
如果它必须是 JSON 而不是一个对象,那么JSON.stringify
它之后(永远不要尝试手动构造 JSON):
const codes = '/123/468x60#/123/336x280#/123/300x600'.split('#');
const sizes = '468x60#336,280|300,250#300,600|300,250'
.split('#')
.map(
// str is something like: '300,600|300,250'
str => str.split('|').map(
// substr is something like: '300,600'
substr => substr.split(/[,x]/).map(Number)
)
);
const adUnits = codes.map((code, i) => ({
code,
mediaTypes: {
banner: {
sizes: sizes[i]
}
},
bids: [{
bidder: 'adserver',
params: {
networkId: 1234
}
}]
}));
console.log(JSON.stringify(adUnits, null, 2));
推荐阅读
- c++ - 在 multipass Ubuntu 20.10 下编译 c++ 时出现间歇性“找不到文件”错误
- google-apps-script - 使用 onChange 检测 Note 更改
- microsoft-graph-api - 从 Microsoft 团队频道获取所有消息和回复 - 图表分页
- c# - 是否可以从 MVVM 弹出 DisplayPromptAsync
- javascript - Javascript 循环值显示为未定义
- php - 将自定义设置添加到 WooCommerce 产品选项卡
- stripe-payments - 条带连接帐户订阅
- vba - 根据单击更改文本框的前景色,并在单击另一个文本框时将其返回到以前的前景色?
- c# - 将每个属性序列化为字节数组
- sql - 在 SQL 查询中重复元组