- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
你好,我在列表中动态插入行。现在只需单击按钮即可发生这种情况,但最终数据将来自数据库。那很好用!
我想要做的是,一旦列表呈现给用户,他/她就会将鼠标移到所需的列表项上。那时应该突出显示该元素。所以我想在每一行中添加 mouseover 和 mouseout 事件。但是事件是在函数声明本身上触发的。请在此处找到 JSfiddle 链接: https://jsfiddle.net/indiaaditya/ycyb9dot/
问题部分在这里::
function AddEventsToTableForEachRow(tableId) {
//Get the NodeList
alert("Function Called!");
var nodelist = document.querySelectorAll(".classTableElement");
var lclCntr = 0;
alert("Elements found:" + nodelist.length);
//Set ID's for all the elements
var strInloop = "";
//This loop sets the ID for each row.
for (lclCntr = 0; lclCntr < nodelist.length; lclCntr++) {
strInloop = "tr" + lclCntr;
nodelist[lclCntr].setAttribute("id", strInloop);
}
//This loop adds event for each row.
for (lclCntr = 0; lclCntr < nodelist.length; lclCntr++) {
strInloop = "tr" + lclCntr;
var rowElement = document.getElementById(strInloop);
rowElement.addEventListener("onmouseover", alert("A"), false);
}
}
JSFiddle代码说明:
1. 单击生成列表按钮添加行。
2.单击 GlowRecord 按钮以突出显示第一行。再次单击它以删除突出显示。这是鼠标悬停和鼠标移出时所需的功能。
3.单击 AddEvents 以生成事件。 这是不起作用的代码部分
AddEvents 调用
AddEventsToTableForEachRow('tblTestList')
功能。但是这个函数会立即调用其中的警报函数调用。
预期结果是调用 AddEventsToTableForEachRow 后,事件应附加到每一行,当鼠标移动到该行时,应显示警告消息。
实际上,如前所述,AddEventsToTableForEachRow 中的警报函数会立即被调用,鼠标悬停时不会执行任何操作。
对于那些质疑我为什么没有使用 jquery 的人:A。我是 JS/HTML/CSS 的新手。我来自 C/C++ 背景,因为使用 HTML/CSS/JS 构建 UI 很容易,所以来到这边。b.我正在快速学习,发现 DOM 更清晰、更容易理解。但是在这个问题上花了 3 天时间后,我已经准备好应对任何事情。 (但如果我得到基于 DOM 的解决方案会更快乐!)
提前致谢。
亲切的问候,阿迪亚
最佳答案
与其将事件监听器添加到每一行,不如将其添加到表中一次。然后,在您的事件处理程序中,您可以使用 event.target
以确保事件发生在正确的元素上。
function mouseOverHandler(event) {
var tr = event.target;
while(tr) {
if (tr.localName === 'tr') {
break;
}
tr = tr.parentNode;
}
// tr will be null if the `<table>` was the event recipient
if (tr) {
console.log(tr.localName, tr.textContent);
}
}
function AddEventsToTable(tableId) {
var table = document.getElementById(tableId);
if (table) {
table.addEventListener("mouseover", mouseOverHandler, false);
}
}
AddEventsToTable('mytable');
<table id="mytable">
<tr>
<td>row 1, col 1</td>
<td>row 1, col 2</td>
<td>row 1, col 3</td>
<td>row 1, col 4</td>
</tr>
<tr>
<td>row 2, col 1</td>
<td>row 2, col 2</td>
<td>row 2, col 3</td>
<td>row 2, col 4</td>
</tr>
<tr>
<td>row 3, col 1</td>
<td>row 3, col 2</td>
<td>row 3, col 3</td>
<td>row 3, col 4</td>
</tr>
</table>
当您的鼠标移动到任何子表时,这确实会触发事件,但我使用 while 循环将事件目标转换为适当的 <tr>
.
关于javascript - JS 将事件添加到动态添加行的列表,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/47720192/
猫f1.txt阿曼维沙尔阿杰贾伊维杰拉胡尔曼尼什肖比特批评塔夫林现在输出应该符合上面给定的条件 最佳答案 您可以在文件读取循环中设置一个计数器并打印它, 计数=0 读取行时做 让我们数一数++ if
我正在尝试查找文件 1 和文件 2 中的共同行。如果公共(public)行存在,我想写入文件 2 中的行,否则打印文件 1 中的非公共(public)行。fin1 和 fin2 是这里的文件句柄。它读
我有这个 SQL 脚本: CREATE TABLE `table_1` ( `IDTable_1` int(11) NOT NULL, PRIMARY KEY (`IDTable_1`) );
我有 512 行要插入到数据库中。我想知道提交多个插入内容是否比提交一个大插入内容有任何优势。例如 1x 512 行插入 -- INSERT INTO mydb.mytable (id, phonen
如何从用户中选择user_id,SUB(row, row - 1),其中user_id=@userid我的表用户,id 为 1、3、4、10、11、23...(不是++) --id---------u
我曾尝试四处寻找解决此问题的最佳方法,但我找不到此类问题的任何先前示例。 我正在构建一个基于超本地化的互联网购物中心,该区域分为大约 3000 个区域。每个区域包含大约 300 个项目。它们是相似的项
preg_match('|phpVersion = (.*)\n|',$wampConfFileContents,$result); $phpVersion = str_replace('"','',
我正在尝试创建一个正则表达式,使用“搜索并替换全部”删除 200 个 txt 文件的第一行和最后 10 行 我尝试 (\s*^(\h*\S.*)){10} 删除包含的前 10 行空白,但效果不佳。 最
下面的代码从数据库中获取我需要的信息,但没有打印出所有信息。首先,我知道它从表中获取了所有正确的信息,因为我已经在 sql Developer 中尝试过查询。 public static void m
很难说出这里问的是什么。这个问题是含糊的、模糊的、不完整的、过于宽泛的或修辞性的,无法以目前的形式得到合理的回答。如需帮助澄清此问题以便重新打开它,visit the help center 。 已关
我试图在两个表中插入记录,但出现异常。您能帮我解决这个问题吗? 首先我尝试了下面的代码。 await _testRepository.InsertAsync(test); await _xyzRepo
这个基本的 bootstrap CSS 显示 1 行 4 列: Text Text Text
如果我想从表中检索前 10 行,我将使用以下代码: SELECT * FROM Persons LIMIT 10 我想知道的是如何检索前 10 个结果之后的 10 个结果。 如果我在下面执行这段代码,
今天我开始使用 JexcelApi 并遇到了这个:当您尝试从特定位置获取元素时,不是像您通常期望的那样使用sheet.getCell(row,col),而是使用sheet.getCell(col,ro
我正在尝试在我的网站上开发一个用户个人资料系统,其中包含用户之前发布的 3 个帖子。我可以让它选择前 3 条记录,但它只会显示其中一条。我是不是因为凌晨 2 点就想编码而变得愚蠢? query($q)
我在互联网上寻找答案,但找不到任何答案。 (我可能问错了?)我有一个看起来像这样的表: 我一直在使用查询: SELECT title, date, SUM(money) FROM payments W
我有以下查询,我想从数据库中获取 100 个项目,但 host_id 多次出现在 urls 表中,我想每个 host_id 从该表中最多获取 10 个唯一行。 select * from urls j
我的数据库表中有超过 500 行具有特定日期。 查询特定日期的行。 select * from msgtable where cdate='18/07/2012' 这将返回 500 行。 如何逐行查询
我想使用 sed 从某一行开始打印 n 行、跳过 n 行、打印 n 行等,直到文本文件结束。例如在第 4 行声明,打印 5-9,跳过 10-14,打印 15-19 等 来自文件 1 2 3 4 5 6
我目前正在执行验证过程来检查用户的旧密码,但问题是我无法理解为什么我的查询返回零行,而预期它有 1 行。另一件事是,即使我不将密码文本转换为 md5,哈希密码仍然得到正确的答案,但我不知道为什么会发生
我是一名优秀的程序员,十分优秀!