mirror of
https://github.com/swc-project/swc.git
synced 2024-12-01 01:13:56 +03:00
37 lines
880 B
TypeScript
37 lines
880 B
TypeScript
// @filename: file.tsx
|
|
// @jsx: preserve
|
|
// @noLib: true
|
|
// @skipLibCheck: true
|
|
// @libFiles: react.d.ts,lib.d.ts
|
|
|
|
import React = require('react');
|
|
|
|
const obj = {};
|
|
const obj1: { x: 2 } = {
|
|
x: 2
|
|
}
|
|
const obj3: {y: true, overwrite: string } = {
|
|
y: true,
|
|
overwrite: "hi"
|
|
}
|
|
|
|
interface Prop {
|
|
x: 2
|
|
y: true
|
|
overwrite: string
|
|
}
|
|
|
|
class OverWriteAttr extends React.Component<Prop, {}> {
|
|
render() {
|
|
return <div>Hello</div>;
|
|
}
|
|
}
|
|
|
|
let anyobj: any;
|
|
// OK
|
|
let x = <OverWriteAttr {...obj} y overwrite="hi" {...obj1} />
|
|
let x1 = <OverWriteAttr {...obj1} {...obj3} />
|
|
let x2 = <OverWriteAttr x={3} overwrite="hi" {...obj1} {...{y: true}} />
|
|
let x3 = <OverWriteAttr overwrite="hi" {...obj1} x={3} {...{y: true, x: 2, overwrite:"world"}} />
|
|
let x4 = <OverWriteAttr {...{x: 2}} {...{overwrite: "world"}} {...{y: true}} />
|
|
let x5 = <OverWriteAttr {...anyobj} /> |