代码之家  ›  专栏  ›  技术社区  ›  HalfWebDev

转换为Antdesign Datepicker的Typescript

  •  2
  • HalfWebDev  · 技术社区  · 6 年前

    dateObj 中的参数 handleDateChange 我的功能

    应用程序.tsx

    import { useState } from 'react';
    import logo from './logo.svg';
    import './App.css'; 
    import { DatePicker } from 'antd';       // for css
    import moment from 'moment';
    
    const App = () => {
        const [date, setDate] = useState(new Date())
        const handleDateChange = (dateObj: Date, dateStr: string) => {
            setDate(dateObj);
        }
        return (
            <div className="App">
                <DatePicker defaultValue={moment(date)} onChange={handleDateChange} />
                <header className="App-header">
                    <img src={logo} className="App-logo" alt="logo" />
                    <p>
                        Edit <code>src/App.tsx</code> and save to reload.
                    </p>
                    <a
                        className="App-link"
                        href="https://reactjs.org"
                        target="_blank"
                        rel="noopener noreferrer"
                    >
                        Learn React
                    </a>
                </header>
            </div>
        );
    }
    
    export default App;
    

    茨林特是这么说的-

    Type'(dateObj:Date,dateStr:string)=>void'不可分配给Type'(Date:Moment,dateString:string)=>void'。 参数“dateObj”和“date”的类型不兼容。 类型“Moment”不可分配给类型“Date”。 类型“Moment”中缺少属性“toDateString”

    但我不知道如何克服这个问题。

    2 回复  |  直到 6 年前
        1
  •  1
  •   Canastro    6 年前

    只是把这个答案推进这个话题,因为它似乎解决了这个问题,而在另一个问题中没有被标记为正确答案: How can moment.js be imported with typescript?


    你需要导入 功能和 时刻

    我在打字机上找到一张便条 here .

    /*~请注意,ES6模块不能直接导出可调用函数。 *~import x=require('someLibrary');

    因此,将moment js导入typescript的代码实际上如下所示:

    import { Moment } from 'moment'
    ....
    let moment = require('moment');
    ...
    interface SomeTime {
      aMoment: Moment,
    }
    ...
    fn() {
      ...
      someTime.aMoment = moment(...);
      ...
    }
    
        2
  •  1
  •   HalfWebDev    6 年前

     const [date, setDate] = useState(moment(new Date()));
     const handleDateChange = (dateObj: moment.Moment, dateStr: string): void => {
        setDate(dateObj);
    }
    

    然后

     <DatePicker defaultValue={date} onChange={handleDateChange} />
    

    Moment 作为 interface 而不是 class 存在于命名空间上,如下所示 reference