为什么 jquery 中的 TD 样式会让标记变得疯狂?

发布于 2024-11-17 19:58:52 字数 286 浏览 2 评论 0原文

我正在尝试向表格中的所有表格单元格添加一个简单的边框。

对于我可以使用的其他一些功能来说,我的标记保持简单非常重要。

假设我像这样设置 tds 样式:

$('td').css('border', '1px solid #000');

这最终是我的结果:

… /td>

类也不适合我想做的事情。为什么我的单元格会以这种荒谬的方式格式化?

I'm trying to add a simple border to all the table cells in a table.

It's important that my markup remains simple for some other functionality I have in place to work.

Let's say I style tds like this:

$('td').css('border', '1px solid #000');

this ends up as my result:

<td style=​"border-top-width:​ 1px;​
border-right-width:​ 1px;​
border-bottom-width:​ 1px;​
border-left-width:​ 1px;​
border-top-style:​ solid;​
border-right-style:​ solid;​
border-bottom-style:​ solid;​
border-left-style:​ solid;​
border-top-color:​ rgb(0, 0, 0)​;​
border-right-color:​ rgb(0, 0, 0)​;​
border-bottom-color:​ rgb(0, 0, 0)​;​
border-left-color:​ rgb(0, 0, 0)​;​
">​…​/td>

Classes also wouldn't be appropriate for what I'm trying to do. Why are my cells being formatted in this ridiculous way?

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(1

甜`诱少女 2024-11-24 19:58:52

这就是浏览器处理速记 CSS 属性的方式;一些浏览器可能会以不同于内部表示的方式实现人类可读的表示,但实际上,

border: 1px solid #000

的简写

border-top-width: 1px;
border-right-width: 1px;
border-bottom-width: 1px;
border-left-width: 1px;
border-top-style: solid;
border-right-style: solid;
border-bottom-style: solid;
border-left-style: solid;
border-top-color: #000;
border-right-color: #000;
border-bottom-color: #000;
border-left-color: #000;

它是#000 的许多可能表示

。我在 Chrome 和 Safari(均为 WebKit 浏览器)中进行了测试,并直接在 DOM 中设置该属性 (element.style.border = '1px Solid #000') 得到了完全相同的结果。这是 WebKit 的行为,不是 jQuery

此外,这是一个很好的例子,它强调了 DOM 与标记不同并且应该区别对待这一事实。即使在 designMode/contentEditable 场景中(这是唯一真正合理使用直接样式而不是 CSS 类的情况),只需抢夺innerHTML 表示存在一系列潜在风险。您会在旧版本的 IE 中看到这种情况的其他表现,其 DOM 的“标记”表示完全是疯狂的。看到类似这样的内容并不少见:

<div class="foo">...</div>

成为:

<DIV CLASS="foo" _JQUERY12903579="qwertyuiop" HASLAYOUT=TRUE etc etc etc>...</DIV>

正如 DOM 和标记不是同一件事一样,重要的是要认识到 attributeproperty 并不相同事物。最终,jQuery.css 方法是通过为 element.style 的属性赋值来实现的(例如 collection.css({ border: '1pxsolid #000' }) 大致相当于 collection.each(function() { this.style.border = '1px Solid #000' })collection.attr('style ', 'border: 1pxsolid #000') 相当于 collection.each(function() { this.setAttribute('style', 'border: 1pxsolid #000'); })

>.通过 风格', ...),您可能会覆盖所有元素的内联样式。

This is how browsers handle shorthand CSS properties; some browsers may implement the human-readable representation differently from the internal representation, but in reality,

border: 1px solid #000

is shorthand for

border-top-width: 1px;
border-right-width: 1px;
border-bottom-width: 1px;
border-left-width: 1px;
border-top-style: solid;
border-right-style: solid;
border-bottom-style: solid;
border-left-style: solid;
border-top-color: #000;
border-right-color: #000;
border-bottom-color: #000;
border-left-color: #000;

with a number of possible representations of #000.

I tested in both Chrome and Safari (both WebKit browsers), and setting that property directly in the DOM (element.style.border = '1px solid #000') had exactly that result. This is the behavior of WebKit, not jQuery.

Furthermore, this is a great example to underscore the fact that the DOM is different from markup, and ought to be treated differently. Even in a designMode/contentEditable scenario (which is the only really reasonable use of direct styling instead of CSS classes), just snatching the innerHTML representation of an element is a whole host of potential risks. You'll see other manifestations of this in older versions of IE, whose "markup" representations of the DOM are completely insane. It's not uncommon to see stuff like:

<div class="foo">...</div>

become:

<DIV CLASS="foo" _JQUERY12903579="qwertyuiop" HASLAYOUT=TRUE etc etc etc>...</DIV>

And just as DOM and markup are not the same thing, it's important to realize that an attribute and a property are not the same thing. Ultimately, the jQuery.css method is implemented by assigning values to properties of element.style (eg collection.css({ border: '1px solid #000' }) is roughly equivalent to collection.each(function() { this.style.border = '1px solid #000' }); while collection.attr('style', 'border: 1px solid #000') is equivalent to collection.each(function() { this.setAttribute('style', 'border: 1px solid #000'); }). By setting the attribute rather than properties, what you're doing is effectively like retroactively editing the HTML markup. This can lead to unpredictable results if you also have properties set that conflict.

Also note that by using attr('style', ...), you are probably overriding all of the elements' inline styles.

~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文