react中html属性怎么写,reactjs – 使用React 16在“DetailedHTMLProps,HTMLDivElement>”类型中不存在属性...

由于React 16现在允许

custom DOM attributes,我试图在我的Typescript代码中利用它:

import * as React from 'react';

但收到此错误消息:

error TS2339: Property ‘size’ does not exist on type

‘DetailedHTMLProps< HTMLAttributes< HTMLDivElement>,HTMLDivElement>’.

这个thread建议进行模块扩充,所以我尝试了这种方式:

import * as React from 'react';

declare module 'react' {

interface HTMLProps {

size?:string;

}

}

相同的错误消息.

最后,我还尝试将页面声明为新的HTML标记:

declare global {

namespace JSX {

interface IntrinsicElements {

page: any

}

}

}

它消除了错误消息,但在编译的代码中完全忽略了size属性,我最终得到:

理想情况下,最后一个是我的首选解决方案.我想在页面自定义标记旁边使用尺寸自定义属性.

tsconfig.js

{

"compilerOptions": {

"outDir": "build/dist","module": "esnext","target": "es5","lib": ["es6","dom"],"sourceMap": true,"allowJs": true,"jsx": "react","moduleResolution": "node","rootDir": "src","forceConsistentCasingInFileNames": true,"noImplicitReturns": true,"noImplicitThis": true,"noImplicitAny": true,"strictNullChecks": true,"suppressImplicitAnyIndexErrors": true,"allowSyntheticDefaultImports": true,"noUnusedLocals": false,"noUnusedParameters": false,"allowUnusedLabels": true,"allowUnreachableCode": true

}

}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
React,通常不建议在JS文件直接HTML代码,而是使用JSX语法来描述UI组件的结构。如果你想从React组件的外部加载HTML并且访问内部函数,可以考虑以下两种方法: 1. 使用dangerouslySetInnerHTML属性React,可以使用dangerouslySetInnerHTML属性HTML代码作为字符串传递给组件,并在组件渲染该HTML代码。但是,这种方法存在安全隐患,因为它可以导致跨站脚本攻击(XSS)。因此,必须确保HTML代码是可信的,并且应该避免在生产环境使用。 以下是一个示例代码: ```jsx function MyComponent() { const html = '<div>Hello World</div>'; function handleClick() { console.log('Button clicked'); } return ( <div> <div dangerouslySetInnerHTML={{ __html: html }}></div> <button onClick={handleClick}>Click me</button> </div> ); } ``` 在这个例子,我们定义了一个字符串变量`html`,它包含要加载的HTML代码。然后,我们在组件的JSX代码使用`dangerouslySetInnerHTML`属性将该HTML代码渲染到页面上。同时,我们还定义了一个内部函数`handleClick`,并将其绑定到一个按钮的`onClick`事件上。 2. 使用React Portals 另一种方法是使用React Portals,它允许你将组件的输出渲染到DOM的任何位置,而不仅仅是组件树的直接父组件。这意味着你可以在组件外部的任何位置加载你的HTML代码,并且仍然可以访问组件内部的函数。 以下是一个示例代码: ```jsx import ReactDOM from 'react-dom'; function MyComponent() { const html = '<div>Hello World</div>'; function handleClick() { console.log('Button clicked'); } return ( <div> <button onClick={handleClick}>Click me</button> </div> ); } function App() { const portalContainer = document.getElementById('portal-container'); return ( <div> <div>Some content here</div> {ReactDOM.createPortal(<MyComponent />, portalContainer)} </div> ); } ``` 在这个例子,我们定义了一个`MyComponent`组件,它包含一个内部函数`handleClick`。然后,在`App`组件,我们使用`createPortal`函数将`MyComponent`组件的输出渲染到`portalContainer`元素。这样,我们就可以在`MyComponent`组件外部加载HTML代码,而仍然可以访问`MyComponent`组件内部的函数。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值