当前位置: 首页 > 面试题库 >

反应colspan不起作用

颛孙正卿
2023-03-14
问题内容

为什么colspan属性在React中不起作用?我创建了呈现以下内容的简单组件:

<table border="1">
  <tr>
    <th colspan="2">people are...</th>
  </tr>
  <tr>
    <td>monkeys</td>
    <td>donkeys</td>
  </tr>
</table>

编辑:解决

这是解决方案。React期望属性名称为 colSpan ,而不是colspan。在浪费了荒谬的时间去发现这个小小的邪恶事实之后,想出了这一点。


问题答案:

来自React的DOM差异文档:

所有DOM属性和属性(包括事件处理程序)都应包含驼峰,以与标准JavaScript样式保持一致。

如果您检查浏览器的控制台,您会看到React对此警告您:

<meta charset="UTF-8">

<script src="https://npmcdn.com/react@15.2.1/dist/react.js"></script>

<script src="https://npmcdn.com/react-dom@15.2.1/dist/react-dom.js"></script>

<script src="https://npmcdn.com/babel-core@5.8.38/browser-polyfill.min.js"></script>

<script src="https://npmcdn.com/babel-core@5.8.38/browser.min.js"></script>

<div id="app"></div>

<script type="text/babel">



var App = React.createClass({

  render() {

    return <table border="1">

      <tbody>

        <tr>

          <th colspan="2">people are...</th>

        </tr>

        <tr>

          <td>monkeys</td>

          <td>donkeys</td>

        </tr>

      </tbody>

    </table>

  }

})



ReactDOM.render(<App who="World"/>, document.querySelector('#app'))



</script>


Warning: Unknown DOM property colspan. Did you mean colSpan?
    in th (created by App)
    in tr (created by App)
    in tbody (created by App)
    in table (created by App)
    in App


 类似资料:
  • 问题内容: 我试图将onscroll事件处理程序添加到特定的dom元素。看下面的代码: 代码非常简单,如您所见,我想处理div#list滚动。当我运行此示例时,它不起作用。所以我尝试直接在render方法上绑定this._handleScroll,它也不起作用。 因此,我打开了chrome inspector,直接使用以下命令添加了onscroll事件: 它正在工作!我不知道为什么会这样。这是Re

  • 问题内容: 我是新来的人,我想做出反应并尝试使用内联样式获取背景图片。但这不起作用。 显示错误“ URL未定义” 问题答案: CSS值始终是字符串。将值用引号引起来,使其成为字符串:

  • 我正在尝试在对话框中设置panelgrid。除了科尔斯潘,一切似乎都在工作。我查过这个PrimeFaces panelGrid的帖子,但它有一年半的历史。从primefaces手册和showcase来看,colspan应该被datatable和PanelGrid接受。 但我找不到我做错了什么。

  • 大家好,我正在与RN一起学习一个简单的聊天应用程序 我在服务器代码中检查了连接与连接事件的连接服务器也可以获取我的套接字ID 但是,任何发射或开启都不起作用。 这是我的服务器代码 这是客户端代码 有了这段代码,当我按下按钮时,我认为socket.on在服务器上工作 此外,当套接字在服务器中连接时,客户端会更改渲染中的文本。 但两者都不起作用。 请帮帮我...

  • 我遇到了一个奇怪的问题。在我的反应原生应用程序中,如果我将事件设置为,它不会被触发,但如果我将相同的设置为中的,它会被触发。我在这里错过了什么? 为什么会这样?这是React Native的问题吗?我使用的是0.43版。

  • 问题内容: 我正在尝试学习react.js,但被困在“ Hello World”脚本中。 我的index.html: 和src / helloworld.js: 当我把这个代码里面的文件,它工作正常,但是当我将其移动到单独的文件中我得到的空白页,并控制台错误: 怎么了 问题答案: 您收到该错误的原因是: 您已经从本地文件系统(例如通过双击)加载了,而不是通过Web服务器加载了 JSX转换器是脚本的