- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
一些帮助将不胜感激。对于新开发人员来说,这里的信息太多了
我正在尝试创建一个这样创建的动态表:
function myFunction2() {
var img = new Image();
var table = document.getElementById("Table1");
var row = table.insertRow(table.length);
for (i = 0; i < 12; i++) {
row.insertCell(i);
}
//Add Txt
row.insertCell(1).innerHTML = "insert";
//Add Images
var Sport = document.createElement("IMG");
Sport.setAttribute("src", "Images/ball.png");
Sport.setAttribute("div", "Sport");
row.insertCell(0).appendChild(Sport);
//Add drop-down list
var dd = document.createElement("select");
dd.name = "SportSelector";
dd.id = "id" + document.getElementById('Table1').rows.length;
dd.options[dd.length] = new Option("Soccer", "value1");
dd.options[dd.length] = new Option("Basket", "value2");
dd.options[dd.length] = new Option("Hockey", "value3");
dd.setAttribute("onchange", "GetSport(this)");
row.insertCell(1).appendChild(dd);
//Done
}
到目前为止一切顺利,但现在我无法尝试调整表格大小,而且我不知道如何执行此操作。现在我正在尝试调整应该只包含一个图标的 Col(0)。
我试着给它起类名“Sport”,在 CSS 中有这个:
Sport {
width: 20 px;
margin-right: 30%;
border: 1px solid #000;
}
但这行不通。任何关于我需要做什么的指示都会很棒?
编辑:
好的,我接受了 Ivan86 的建议,我有几个问题?
看起来你的编辑破坏了我代码的另一部分
function GetSport(val) {
var x = val.id;
var x = x.replace("id", "");
var table = document.getElementById("Table1")
table.rows[x - 1].cells[0].innerHTML = "<img src='Images/ball.png'/>";
//alert("The input value has changed. The new value is: " + val.id);
}
此代码还应该根据下拉列表中的选择更改 img 文件。关于如何修复的任何建议?
另外这部分你的建议我没有补充:
<table id="Table1">
<tr>
<td colspan="12">OLD ROW</td>
</tr>
</table>
<br/>
<input type="button" onclick="myFunction2()" value="add a new row" />
并且 txt“插入”不应该是代码的任何部分,我更新为:
function myFunction2()
{
var img = new Image();
var table = document.getElementById("Table1");
var row = table.insertRow(table.length);
// make a cell array
var cells = [];
for (i = 0; i < 13; i++)
{
// add the cell to the table and to the cell array
cells.push(row.insertCell(i));
}
//Add Txt
//Add Images
var Sport = document.createElement("IMG");
Sport.setAttribute("src", "Images/ball.png");
Sport.setAttribute("height", "20px");
Sport.setAttribute("width", "20px");
cells[0].appendChild(Sport);
// to add class
cells[0].classList.add('Sport');
// to add CSS to the first cell
cells[0].style.width = '15px';
// create margin-right effect
cells[1].style.padding = '0 0 0 0px';
//Add drop-down list
var dd = document.createElement("select");
dd.name = "SportSelector";
dd.id = "id" + document.getElementById('Table1').rows.length;
dd.options[dd.length] = new Option("Soccer", "value1");
dd.options[dd.length] = new Option("Basket", "value2");
dd.options[dd.length] = new Option("Hockey", "value3");
dd.setAttribute("onchange", "GetSport(this)");
cells[1].appendChild(dd);
//Done
}
看笔
My project通过弗雷德里克(
@frederik84)在
CodePen .
最佳答案
您可以保存 inserted columns
在array
这样您以后就可以轻松定位他们。
我添加了一个 width
到 table
和一些基本示例 CSS
.
我也没有使用 class
Sport
对于单元格样式,但我确实添加了 class
sport
到 column
如果你需要那样的话。
代码如下:
注意: margins
不要在 table cells
上工作,您只需更改 cell width
或者可能使用 padding-right
.但我认为最好的方法是设置 padding-left
在第二列。
function myFunction2()
{
var img = new Image();
var table = document.getElementById("Table1");
var row = table.insertRow(table.length);
// make a cell array
var cells = [];
for (i = 0; i < 12; i++)
{
// add the cell to the table and to the cell array
cells.push(row.insertCell(i));
}
//Add Txt
//Add Images
var Sport = document.createElement("IMG");
Sport.setAttribute("src", "https://cdn2.iconfinder.com/data/icons/free-3d-printer-icon-set/256/Model.png");
Sport.setAttribute("height", "20px");
Sport.setAttribute("width", "20px");
cells[0].appendChild(Sport);
// to add class
cells[0].classList.add('Sport');
// to add CSS to the first cell
cells[0].style.width = '20px';
cells[0].style.border= '1px solid #09f';
// create margin-right effect
cells[1].style.padding = '0 0 0 20px';
//Add drop-down list
var dd = document.createElement("select");
dd.name = "SportSelector";
dd.id = "id" + document.getElementById('Table1').rows.length;
dd.options[dd.length] = new Option("Soccer", "soccer");
dd.options[dd.length] = new Option("Basket", "basket");
dd.options[dd.length] = new Option("Hockey", "hockey");
dd.setAttribute("onchange", "GetSport(this.id)");
cells[1].appendChild(dd);
//Done
}
function GetSport(thisID)
{
var table = document.getElementById("Table1")
var imageSRC = '';
var elmnt = document.getElementById(thisID);
// get currently selected option value
var str = elmnt.options[elmnt.selectedIndex].value;
// if else to set the image src
if(str == 'soccer') { imageSRC = 'https://cdn2.iconfinder.com/data/icons/free-3d-printer-icon-set/256/Model.png'; }
else if(str == 'basket') { imageSRC = 'https://dsfrc4icyn4oa.cloudfront.net/wp-content/uploads/2015/08/07134130/Approve-Sample-Hexa-Icon-250.png'; }
else { imageSRC = 'http://nexticon.net/media/samples/check.png'; }
// extract only the row number
var x = thisID.replace("id", "");
// throw in the variable with the dynamic image path
table.rows[x - 1].cells[0].innerHTML = '<img src="' + imageSRC + '" width="20px" height="20px" />';
//alert("The input value has changed. The new value is: " + val.id);
}
#Table1
{
position:relative;
margin:0 auto;
width:80%;
}
<table id="Table1">
<tr>
<td colspan="12">OLD ROW</td>
</tr>
</table>
<br/>
<input type="button" onclick="myFunction2()" value="add a new row" />
编辑: 我添加了函数 GetSport(thisID)
到代码并更改dd.setAttribute("onchange", "GetSport(this)");
至 dd.setAttribute("onchange", "GetSport(this.id)");
在函数中 myFunction2()
, 所以 select element
通过 id
而不是 this
.
我添加了一个示例变量 imageSRC
和一个 if-else
制作different image paths
基于 selected value
.您可以在此处使用不同的方法,例如使用 array
存储 paths
,或者图片可以调用例如soccer5135616.jpg basket894237582.jpg等。
关于javascript - CSS、JavaScript风格的动态表格,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/48344687/
Textmate 语法(.tmLanguage 文件)有时以 XML 格式表示。 我想转换为更易读的格式(即 JSON 或 YAML)以集成到 VS Code 语法突出显示扩展中。 为了澄清我的意思,
如何通过 pandas 样式隐藏列标签?有一个 hide_index() 方法可以删除索引行,不幸的是 hide_column() 标签会删除整个列(标题和数据)。我只想隐藏标题。谢谢! 最佳答案 s
我正在考虑为一组服务使用 SOA 架构来支持我咨询的业务,以前我们使用数据库集成,其中每个应用程序从共享的 MS SQL 数据库中挑选出它需要的东西并使用它等等。我们有各种与怪物数据库(包括 java
所以我有以下代码,我想知道 Objective-C 中哪种“风格”被认为更好。 选项 1: id temp = [dictionary objectForKey: @"aBooleanValue"];
当创建一个没有类参数的对象时,我很难决定是否应该包含空括号。一个具体的例子:我正在与现有的 Java 代码交互,并创建一个实现名为 EventResponder 的接口(interface)的对象。我
我有一个抽象类Stack和一个扩展它的类:MyStack。我需要为 MyStack 创建一个复制构造函数。只传入 MyStack 对象更好,还是传入任何 Stack 对象更好? public MySt
我正在考虑将那些在函数体中未修改的 Python 函数参数拼写为 ALL_UPPERCASE,向此类 API 的用户发出信号,表明传递的值不会被修改(如果一切都如广告所言,无论如何) )。我不知道这会
我的 build.gradle 文件、staging、stable 和 production 以及默认构建类型 debug 和 release。对于其中的每一个,我都有不同的 AAR 文件,例如,我有
假设我有以下文件: main.cpp 例程.cpp 例程.h 进一步假设 main.cpp 调用了在 routine.cpp 中定义的函数 routine(),但是 routine.cpp 还包含仅由
我对此进行了一些搜索,但实际上我还没有找到 MySQL 中用于创建外键的样式概念是什么 - 在创建表定义中或在 alter 语句中。谢谢。 最佳答案 何时创建外键: 如果在创建表时明确需要外键,则在创
您好,我正在尝试将 Android 应用风格(免费且完整)实现为动态壁纸。在 Eclipse 中,我曾经使用以下代码从我自己的 Android Activity 打开动态壁纸预览: I
我的 Android 应用程序有两种不同的风格,lite 和 pro。在应用程序中,我有一个名为 customFragment.java 的类,它包含在 main 中(不同风格之间没有区别)并且还包含
我有一个包含多个子目录的项目,如下所示: /opt/exampleProject/src ├── __init__.py ├── dir1 │ ├── __init__.py │ ├──
假设我们有类似的东西 int f(int n); .... do{ int a = b; int b = f(a); } 这样说有没有风险 do{ int b = f(b);
是否有风格指导或理由来选择其中一种模式而不是另一种? 最小化上下文管理器下的代码量“感觉”更干净,但我无法指出具体原因。这可能只是偏好,并没有关于此事的官方指导。 1) 里面的所有代码都有上下文。 w
module Hints module Designer def self.message "Hello, World!" end
我正在开发一个具有多种风格的 android 项目。 这很好用,我可以自定义应用程序的元素,例如颜色和字符串资源。 我想让一些风格基于 AppCompat 浅色主题,一些基于 AppCompat 深色
因此,这不起作用,因为 seatsAvailable 是最终的。如何使用更多的 lambda 风格的从头开始的方式来完成我想要完成的事情? final boolean seatsAvailable =
考虑以下代码: cpu_set_t cpuset; CPU_ZERO(&cpuset); CPU_SET(0, &cpuset); sched_setaffinity(0, sizeof(cpuset
从历史上看,我总是这样编写我的异常处理代码: Cursor cursor = null; try { cursor = db.openCursor(null, null
我是一名优秀的程序员,十分优秀!