- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
我正在为一个个人网站编写一些代码,作为一个副项目。我对 html 和 javascript 有一些经验,但遇到了一个我无法识别的奇怪错误。更具体的上下文...
我有一个包含一些数据的 XML 文件,我想在 javascript 中根据该数据生成一个 HTML 表格(代码如下所示)。该表按预期生成(woot),但在表的正下方打印了“未定义”一词。我不确定这是从哪里来的,因为我的 javascript 生成的 html 包含在“tbody”标签中。我想这是一些更高级的人可以轻易指出的奇怪的小众错误(我目前对我的 javascript 有点生疏)。
我在将我的问题转换为一组可通过 google 搜索的关键字时遇到了一些麻烦,这就是为什么我认为我会在此处发布有关它的原因。在我决定重构之前,我的表格最初是用 HTML 硬编码的,当所有内容都被硬编码时,我没有遇到这个问题,所以我想它是由我的重构引入的。
我的表格 html 代码...
<h2 class="centered-title">Ability Scores</h2>
<table id="ability_scores"></table>
我用于生成表格的 javascript 代码...
//////////////////////////////////////////////////////////
// Main Functionality
var xhr = new XMLHttpRequest();
xhr.open('GET', '../stats.xml', true);
xhr.timeout = 2000;
xhr.onload = function() { document.getElementById("ability_scores").innerHTML = generate_ability_score_table(this.responseXML); }
xhr.ontimeout = function(e) {};
xhr.send(null);
//////////////////////////////////////////////////////////
// Helper Functions
// GENERATE ABILITY SCORE TABLE FUNCTION
// generates the ability score table html code
// given the xml file with the necessary information
function generate_ability_score_table(xml)
{
// generate table header
var table_header = generate_ability_score_table_header();
// generate all the table entries
var table_entries;
var abilities = xml.getElementsByTagName("ability");
var proficiency = parseFloat(xml.getElementsByTagName("proficiency")[0].childNodes[0].nodeValue);
for (var i = 0; i < abilities.length; i++)
{
var table_entry = generate_ability_score_table_entry(abilities[i], proficiency);
table_entries+= table_entry;
}
return `<tbody>${table_header}${table_entries}</tbody>`;
}
// GENERATE ABILITY SCORE TABLE HEADER FUNCTION
// generates the table header of the ability score table dumbly
function generate_ability_score_table_header()
{
return "<tr><th>Ability</th><th>Score</th><th>Modifier</th><th>Save</th></tr>";
}
// GENERATE ABILITY SCORE TABLE ENTRY FUNCTION
// generates an entry to the ability score table
// corresponding to the ability passed into the function
function generate_ability_score_table_entry(ability, proficiency)
{
var name = ability.children[0].childNodes[0].nodeValue;
var score = parseFloat(ability.children[1].childNodes[0].nodeValue);
var is_proficient = parseFloat(ability.children[2].childNodes[0].nodeValue);
var modifier = get_modifier(score); // <-- this function is just a wrapper for a switch statement
var save = modifier + (is_proficient * proficiency);
return `<tr><td>${name}</td><td>${score}</td><td>${modifier}</td><td>${save}</td></tr>`;
}
编辑这是相关的xml代码:
<stats>
<proficiency>3</proficiency>
<abilityScores>
<ability>
<name>Strength</name>
<score>8</score>
<proficient>0</proficient>
</ability>
<ability>
<name>Dexterity</name>
<score>18</score>
<proficient>1</proficient>
</ability>
<ability>
<name>Constitution</name>
<score>11</score>
<proficient>0</proficient>
</ability>
<ability>
<name>Intelligence</name>
<score>10</score>
<proficient>0</proficient>
</ability>
<ability>
<name>Wisdom</name>
<score>12</score>
<proficient>0</proficient>
</ability>
<ability>
<name>Charisma</name>
<score>18</score>
<proficient>1</proficient>
</ability>
</abilityScores>
</stats>
这是我在打开开发工具时遇到的问题的屏幕截图,以便您更全面地了解问题:
非常感谢能帮我解决这个问题的人! :)
最佳答案
啊,小错误。对于变量 table_entries
,您无需在此处将其初始化为任何内容:
// generate all the table entries
var table_entries;
所以它的初始值是 JS undefined。当您尝试在此处连接时:
table_entries+= table_entry;
在循环中第一次,它将文字字符串“undefined”与能力的新第一行连接起来,这导致显示实际文本“undefined”和一堆格式错误的 HTML。修复应该只是将 var table_entries;
更改为 var table_entries = "";
关于javascript - javascript 生成的 html 表中的 Ghost undefined #text 元素,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/56248369/
我目前正在创建一个正则表达式来拆分所有匹配以下格式的字符串:&[text(text - text text) !text]。这里的文本实际上可以是任何字符。并且间距很重要。文本将如图所示列出。 我已经
这个问题在这里已经有了答案: Remove duplicate commas and extra commas at start/end with RegExp in Javascript, and
我有以下代码。 from xml.dom.minidom import Document doc = Document() root = doc.createElement('root') doc.a
这个问题在这里已经有了答案: 关闭 10 年前。 Possible Duplicate: Find text string in jQuery and make it bold 如何使用 jQuer
我使用 libmagic 在我的元素的 Web 界面中获取文件的 MIME 类型。我在 css 和 js 文件上得到文本/纯 mime 类型。 例如 chromium 显示以下警告: Resource
起初我必须阅读很多教程,但我仍然不知道我做错了什么...... 我想内联使用 4 个 div。在我想放置的那些 div 中:文本、图像、文本、文本。我希望中间文本自动设置为最大宽度。 我写了一个简单的
我想替换所有出现的 [b: "text"]至text使用 JavaScript 和 RegEx。目前我知道如何替换 [b: ""]至使用'/\[b: ""\]/g'但我不知道如果 " 之间有文本该怎么
这可能是一个幼稚的问题,但我想知道是否有比使用 text() 更好的方法将文本添加到绘图中。注意,我也在使用 layout()以及。具体来说,我有一个情节的一部分,我想在其中添加一些带有标题的文本,然
我必须反复从 latex 源粘贴代码,因此每次都必须做很多查找和替换操作('“a'=>'ä','” o'=>'ö',...) 。 有没有一种方法可以存储这些搜索和替换规则,例如,我可以通过一次按键执行
当我在Sublime Text 3代码屏幕中编写代码时,它连续地向右滑动,如图所示。我该怎么办? 请注意第10行。 最佳答案 如果您只想为当前 View (正在编辑的当前文件)激活自动换行,只需vie
是否有可能更改 sublime text 中的默认字体目录?我只想使用可移植 sublime 文本存储在我的 pendrive 上的字体,这样我就不必在我使用可移植 sublime 文本的每台机器上安
我是 Android 开发的新手,我有一个愚蠢的问题。如何将“文本字段”框放在一行中的文本旁边。 例子: Please Enter the number: [ ] 关于 "t
我想自动将“我的文本”更改为“我的文本”,因为这是用德语写的正确方式。引号可以在文本中的任何位置。 有没有一种简单的方法可以实现这一点? 解决方案应该检查第一个字符,最后一个字符,比如“this”,或
我想知道是否有特殊的语法来绑定(bind)与现有文本连接的文本。 像这样。 显然,这行不通。 什么是最佳实践? 使用 SL4。 最佳答案 使用StringFormat在 Binding 上。 WPF
我认为它应该打印“真实文本”,因为它相当于 true console.log('true text' || true ? 'text' : 'text1'); 但是,输出是“文本”;抱歉,如果是愚蠢的
有没有办法通过 css 打破文本,以便中间有一个“空白”?目前我正在通过手工打破文本来解决这个问题 -但这是愚蠢的。我知道有一个函数可以让文本在另一个 div 中结束和开始,但 IE 不支持它。 文本
我想为我的Tcl/Tk工具实现一个效果:在text控件中,根据具体情况,希望高亮一些线条的背景色,其他线条正常透明.有可能吗? 我尝试了一些选项,例如:-highlightbackground 、-i
我正在尝试解析原始维基百科文章内容,例如the article on Sweden ,使用re.sub()。但是,我在尝试替换 {{some text}} block 时遇到了问题,因为它们可以包含更
我试图先删除 ComboBox 中的所有内容。然后在其前面添加文本,但保留了一些旧文本。有没有办法重置或清除 ComboBox?或者我怎样才能最好地实现这一目标? public void GetBad
我知道我们应该创建 Example对象并将其传递给 nlp.update() 方法。根据 docs 中的示例, 我们有 for raw_text, entity_offsets in train_da
我是一名优秀的程序员,十分优秀!