- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我有 15 个部分(称为基础),每个部分都有自己的一组字母按钮。
我要做的就是将字母数字与它们所在的基数/部分相关联。例如,如果用户单击基数 7 下的字母“B”,我想返回该用户已单击位于基数 7
B
我将我需要的所有数据放入 2 个数组中并动态生成字母表。一切都按预期工作,但我无法将字母与底座相关联。
您可以查看下面的演示并打开控制台日志并尝试单击任何按钮。
到目前为止,这是我的代码。
正如您将看到的,我试图从第二个字母表循环内的第一个 forEach
循环返回 base[i].id
。
console.log(alphabet[i].id + ' has been clicked on ' + base[i].id);
这将返回以下内容
A has been clicked on base1
B has been clicked on base2
C has been clicked on base3
但他们都应该说是 base7,因为按钮所在的位置。
更重要的是,下面的代码应该绑定(bind)这两个数组,因为它需要应用纹理的base
名称/编号
setMaterialUIDPending (base[i].name, AlbedoPBR, alphabet[i].id+"-letter");
我希望我说得有道理。
let base = [
{ 'id': 'base1', 'btn': 'b1-include', "name": "baseone" },
{ 'id': 'base2', 'btn': 'b2-include', "name": "basetwo" },
{ 'id': 'base3', 'btn': 'b3-include', "name": "basethree" },
{ 'id': 'base4', 'btn': 'b4-include', "name": "basefour" },
{ 'id': 'base5', 'btn': 'b5-include', "name": "basefive" },
{ 'id': 'base6', 'btn': 'b6-include', "name": "basesix" },
{ 'id': 'base7', 'btn': 'b7-include', "name": "baseseven" },
{ 'id': 'base8', 'btn': 'b8-include', "name": "baseeight" },
{ 'id': 'base9', 'btn': 'b9-include', "name": "basenine" },
{ 'id': 'base10', 'btn': 'b10-include', "name": "baseten" },
{ 'id': 'base11', 'btn': 'b11-include', "name": "baseeleven" },
{ 'id': 'base12', 'btn': 'b12-include', "name": "basetwelve" },
{ 'id': 'base13', 'btn': 'b13-include', "name": "basethirteen" },
{ 'id': 'base14', 'btn': 'b14-include', "name": "basefourteen" },
{ 'id': 'base15', 'btn': 'b15-include', "name": "basefifteen" },
];
let alphabet = [
{ "id":"A", "url":"https://example.com/A.png" },
{ "id":"B", "url":"https://example.com/B.png" },
{ "id":"C", "url":"https://example.com/C.png" }
];
let preview = $('.preview');
$.each(base, function(i, v) {
let $collapse = $('<div>', {'class': 'collapse', id: base[i].id});
let $btn = $('<a>', {'href': '#', 'class': 'btn btn-sm btn-primary', id: base[i].btn});
let $letters = $('<div>', {'class': 'letters'});
$btn.text(base[i].btn);
preview.append($collapse);
$btn.on('click', function() {
if($(this).attr('data-click-state') == 1) {
$(this).attr('data-click-state', 0);
setOpacity(base[i].name, 0.2);
} else {
$(this).attr('data-click-state', 1);
setOpacity(base[i].name, 1);
}
});
$collapse.append($btn);
$collapse.append($letters);
$.each(alphabet, function (i, v) {
let $href = $("<a>", {id: alphabet[i].id, "class": "btn btn-sm btn-dark", 'href': '#', 'title': alphabet[i].id, 'data-src': alphabet[i].url, 'data-base': base[i].id});
$href.text(alphabet[i].id);
$href.on('click', function(){
console.log(alphabet[i].id + ' has been clicked on ' + base[i].id);
setMaterialUIDPending (base[i].name, AlbedoPBR, alphabet[i].id+"-letter");
addTexture(alphabet[i].url, 'N-letter', true);
});
$letters.append($href);
});
});
.preview ul {
list-style-type: none;
display: flex;
flex-wrap: wrap;
}
.preview ul li {
flex: 1 0 25%;
margin: 5px;
}
<script src="https://code.jquery.com/jquery-3.4.1.min.js"></script>
<script src="https://stackpath.bootstrapcdn.com/bootstrap/4.3.1/js/bootstrap.bundle.min.js"></script>
<link href="https://stackpath.bootstrapcdn.com/bootstrap/4.3.1/css/bootstrap.min.css" rel="stylesheet" />
<div class="preview">
<ul>
<li id="b1"><a class="btn btn-sm btn-dark" data-toggle="collapse" href="#base1" role="button" aria-expanded="false" aria-controls="base1">Base 1</a></li>
<li id="b2"><a class="btn btn-sm btn-dark" data-toggle="collapse" href="#base2" role="button" aria-expanded="false" aria-controls="base2">Base 2</a></li>
<li id="b3"><a class="btn btn-sm btn-dark" data-toggle="collapse" href="#base3" role="button" aria-expanded="false" aria-controls="base3">Base 3</a></li>
<li id="b4"><a class="btn btn-sm btn-dark" data-toggle="collapse" href="#base4" role="button" aria-expanded="false" aria-controls="base4">Base 4</a></li>
<li id="b5"><a class="btn btn-sm btn-dark" data-toggle="collapse" href="#base5" role="button" aria-expanded="false" aria-controls="base5">Base 5</a></li>
<li id="b6"><a class="btn btn-sm btn-dark" data-toggle="collapse" href="#base6" role="button" aria-expanded="false" aria-controls="base5">Base 6</a></li>
<li id="b7"><a class="btn btn-sm btn-dark" data-toggle="collapse" href="#base7" role="button" aria-expanded="false" aria-controls="base5">Base 7</a></li>
<li id="b8"><a class="btn btn-sm btn-dark" data-toggle="collapse" href="#base8" role="button" aria-expanded="false" aria-controls="base8">Base 8</a></li>
<li id="b9"><a class="btn btn-sm btn-dark" data-toggle="collapse" href="#base9" role="button" aria-expanded="false" aria-controls="base9">Base 9</a></li>
<li id="b10"><a class="btn btn-sm btn-dark" data-toggle="collapse" href="#base10" role="button" aria-expanded="false" aria-controls="base10">Base 10</a></li>
<li id="b11"><a class="btn btn-sm btn-dark" data-toggle="collapse" href="#base11" role="button" aria-expanded="false" aria-controls="base11">Base 11</a></li>
<li id="b12"><a class="btn btn-sm btn-dark" data-toggle="collapse" href="#base12" role="button" aria-expanded="false" aria-controls="base12">Base 12</a></li>
<li id="b13"><a class="btn btn-sm btn-dark" data-toggle="collapse" href="#base13" role="button" aria-expanded="false" aria-controls="base13">Base 13</a></li>
<li id="b14"><a class="btn btn-sm btn-dark" data-toggle="collapse" href="#base14" role="button" aria-expanded="false" aria-controls="base14">Base 14</a></li>
<li id="b15"><a class="btn btn-sm btn-dark" data-toggle="collapse" href="#base15" role="button" aria-expanded="false" aria-controls="base15">Base 15</a></li>
</ul>
</div>
最佳答案
您正在使用相同的迭代变量 i
和 v
在两个$.each
循环。所以当你遍历 alphabet
时, base[i]
使用 alphabet
中的索引,而不是 base
中的索引.您应该使用不同的变量。
正如我在评论中提到的,您不需要为数组编制索引,这就是使用 $.each
的全部意义所在-- 回调参数是数组的当前元素。因此,只需使用比 v
更多不同的名称在每个数组中。
let base = [
{ 'id': 'base1', 'btn': 'b1-include', "name": "baseone" },
{ 'id': 'base2', 'btn': 'b2-include', "name": "basetwo" },
{ 'id': 'base3', 'btn': 'b3-include', "name": "basethree" },
{ 'id': 'base4', 'btn': 'b4-include', "name": "basefour" },
{ 'id': 'base5', 'btn': 'b5-include', "name": "basefive" },
{ 'id': 'base6', 'btn': 'b6-include', "name": "basesix" },
{ 'id': 'base7', 'btn': 'b7-include', "name": "baseseven" },
{ 'id': 'base8', 'btn': 'b8-include', "name": "baseeight" },
{ 'id': 'base9', 'btn': 'b9-include', "name": "basenine" },
{ 'id': 'base10', 'btn': 'b10-include', "name": "baseten" },
{ 'id': 'base11', 'btn': 'b11-include', "name": "baseeleven" },
{ 'id': 'base12', 'btn': 'b12-include', "name": "basetwelve" },
{ 'id': 'base13', 'btn': 'b13-include', "name": "basethirteen" },
{ 'id': 'base14', 'btn': 'b14-include', "name": "basefourteen" },
{ 'id': 'base15', 'btn': 'b15-include', "name": "basefifteen" },
];
let alphabet = [
{ "id":"A", "url":"https://example.com/A.png" },
{ "id":"B", "url":"https://example.com/B.png" },
{ "id":"C", "url":"https://example.com/C.png" }
];
let preview = $('.preview');
$.each(base, function(i, cur_base) {
let $collapse = $('<div>', {'class': 'collapse', id: cur_base.id});
let $btn = $('<a>', {'href': '#', 'class': 'btn btn-sm btn-primary', id: cur_base.btn});
let $letters = $('<div>', {'class': 'letters'});
$btn.text(cur_base.btn);
preview.append($collapse);
$btn.on('click', function() {
if($(this).attr('data-click-state') == 1) {
$(this).attr('data-click-state', 0);
setOpacity(cur_base.name, 0.2);
} else {
$(this).attr('data-click-state', 1);
setOpacity(cur_base.name, 1);
}
});
$collapse.append($btn);
$collapse.append($letters);
$.each(alphabet, function (i, letter) {
let $href = $("<a>", {id: letter.id, "class": "btn btn-sm btn-dark", 'href': '#', 'title': letter.id, 'data-src': letter.url, 'data-base': cur_base.id});
$href.text(letter.id);
$href.on('click', function(){
console.log(letter.id + ' has been clicked on ' + cur_base.id);
setMaterialUIDPending (cur_base.name, AlbedoPBR, letter.id+"-letter");
addTexture(letter.url, 'N-letter', true);
});
$letters.append($href);
});
});
.preview ul {
list-style-type: none;
display: flex;
flex-wrap: wrap;
}
.preview ul li {
flex: 1 0 25%;
margin: 5px;
}
<script src="https://code.jquery.com/jquery-3.4.1.min.js"></script>
<script src="https://stackpath.bootstrapcdn.com/bootstrap/4.3.1/js/bootstrap.bundle.min.js"></script>
<link href="https://stackpath.bootstrapcdn.com/bootstrap/4.3.1/css/bootstrap.min.css" rel="stylesheet" />
<div class="preview">
<ul>
<li id="b1"><a class="btn btn-sm btn-dark" data-toggle="collapse" href="#base1" role="button" aria-expanded="false" aria-controls="base1">Base 1</a></li>
<li id="b2"><a class="btn btn-sm btn-dark" data-toggle="collapse" href="#base2" role="button" aria-expanded="false" aria-controls="base2">Base 2</a></li>
<li id="b3"><a class="btn btn-sm btn-dark" data-toggle="collapse" href="#base3" role="button" aria-expanded="false" aria-controls="base3">Base 3</a></li>
<li id="b4"><a class="btn btn-sm btn-dark" data-toggle="collapse" href="#base4" role="button" aria-expanded="false" aria-controls="base4">Base 4</a></li>
<li id="b5"><a class="btn btn-sm btn-dark" data-toggle="collapse" href="#base5" role="button" aria-expanded="false" aria-controls="base5">Base 5</a></li>
<li id="b6"><a class="btn btn-sm btn-dark" data-toggle="collapse" href="#base6" role="button" aria-expanded="false" aria-controls="base5">Base 6</a></li>
<li id="b7"><a class="btn btn-sm btn-dark" data-toggle="collapse" href="#base7" role="button" aria-expanded="false" aria-controls="base5">Base 7</a></li>
<li id="b8"><a class="btn btn-sm btn-dark" data-toggle="collapse" href="#base8" role="button" aria-expanded="false" aria-controls="base8">Base 8</a></li>
<li id="b9"><a class="btn btn-sm btn-dark" data-toggle="collapse" href="#base9" role="button" aria-expanded="false" aria-controls="base9">Base 9</a></li>
<li id="b10"><a class="btn btn-sm btn-dark" data-toggle="collapse" href="#base10" role="button" aria-expanded="false" aria-controls="base10">Base 10</a></li>
<li id="b11"><a class="btn btn-sm btn-dark" data-toggle="collapse" href="#base11" role="button" aria-expanded="false" aria-controls="base11">Base 11</a></li>
<li id="b12"><a class="btn btn-sm btn-dark" data-toggle="collapse" href="#base12" role="button" aria-expanded="false" aria-controls="base12">Base 12</a></li>
<li id="b13"><a class="btn btn-sm btn-dark" data-toggle="collapse" href="#base13" role="button" aria-expanded="false" aria-controls="base13">Base 13</a></li>
<li id="b14"><a class="btn btn-sm btn-dark" data-toggle="collapse" href="#base14" role="button" aria-expanded="false" aria-controls="base14">Base 14</a></li>
<li id="b15"><a class="btn btn-sm btn-dark" data-toggle="collapse" href="#base15" role="button" aria-expanded="false" aria-controls="base15">Base 15</a></li>
</ul>
</div>
关于javascript - 如何在 jQuery 中使用 'join' 和循环遍历 2 个关联数组?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/56242600/
我正在测试设置SQLAlchemy以映射现有数据库。这个数据库是很久以前自动建立的,它是由我们不再使用的先前的第三方应用程序创建的,因此 undefined 某些预期的事情,例如外键约束。该软件将管理
这个问题在这里已经有了答案: What is the difference between "INNER JOIN" and "OUTER JOIN"? (28 个答案) 关闭 7 年前。 INNE
这个问题在这里已经有了答案: What is the difference between "INNER JOIN" and "OUTER JOIN"? (29 个回答) 关闭7年前. INNER J
假设有两个表: table1.c1 table1.c2 1 1 A 2 1 B 3 1 C 4 2
假设有两个表: table1.c1 table1.c2 1 1 A 2 1 B 3 1 C 4 2
一.先看一些最简单的例子 例子 Table A aid adate 1 a1 2&nb
数据库操作语句 7. 外连接——交叉查询 7.1 查询 7.2 等值连接 7.3 右外
我有两个表 'users' 和 'lms_users' class LmsUser belongs_to :user end class User has_one :lms_user
我试图避免在 Rails 中对我的 joins 进行字符串插值,因为我注意到将查询器链接在一起时灵活性会降低。 也就是说,我觉得 joins(:table1) 比 joins('inner join
我有这个代码 User.find(:all, :limit => 10, :joins => :user_points, :select => "users.*, co
我刚刚开始探索 Symfony2,我很惊讶它拥有如此多的强大功能。我开始做博客教程在: http://tutorial.symblog.co.uk/ 但使用的是 2.1 版而不是 2.0 我的问题是我
什么是 SQL JOIN什么是不同的类型? 最佳答案 插图来自 W3schools : 关于SQL JOIN 和不同类型的 JOIN,我们在Stack Overflow上找到一个类似的问题: http
我有两个 Hive 表,我正在尝试加入它们。这些表没有被任何字段聚集或分区。尽管表包含公共(public)键字段的记录,但连接查询始终返回 0 条记录。所有数据类型都是“字符串”数据类型。 连接查询很
我正在使用 Solr 的(4.0.0-beta)连接功能来查询包含具有父/子关系的文档的索引。连接查询效果很好,但我只能在搜索结果中获得父文档。我相信这是预期的行为。 但是,是否有可能在搜索结果中同时
我正在使用可用的指南/api/书籍自学 Rails,但我无法理解通过三种方式/嵌套 has_many :through 关联进行的连接。 我有用户与组相关联:通过成员(member)资格。 我在多对多
什么是 SQL JOIN,有哪些不同的类型? 最佳答案 插图来自 W3schools : 关于SQL JOIN 和不同类型的 JOIN,我们在Stack Overflow上找到一个类似的问题: htt
我正在尝试访问数据库的两个表。在商店里,我保留了一个事件列表,其中包含 Table Event id, name,datei,houri, dateF,Hourf ,capacity, age ,de
我有 4 个表:booking、address、search_address 和 search_address_log 表:(相关列) 预订:(pickup_address_id, dropoff_a
我在YML中有以下结构:。我正试着创造一个这样的结构:。作业名称和脚本用~分隔,作业用;分隔。。我可以使用以下命令使其正常工作。然而,我想知道是否可以用一个yq表达式来完成,而不是通过管道再次使用yq
我在YML中有以下结构:。我正试着创造一个这样的结构:。作业名称和脚本用~分隔,作业用;分隔。。我可以使用以下命令使其正常工作。然而,我想知道是否可以用一个yq表达式来完成,而不是通过管道再次使用yq
我是一名优秀的程序员,十分优秀!