コンポーネントのメソッドであるfillCalendar()
を独自のjsファイルに抽出し、代わりにインポートすることで、この反応コンポーネントをクリーンアップしようとしました。もともとthis.state.datesArrayはcomponentWillMount()ライフサイクルメソッドで設定されていました。今、私はこれをリアクションドキュメント 推奨 であるため、コンストラクタ内で直接初期化しようとしています。この方法でこれを行うと、「TypeError:Object(...)is a function not」エラーがスローされますが、その理由はわかりません。 Calendar.jsが こちらを参照 のように見えるために使用するものを次に示します。
Calendar.js
import React, { Component } from 'react';
import { fillCalendar } from '../calendar.tools'
class Calendar extends Component {
constructor(props) {
super(props)
this.state = {
datesArray: fillCalendar(7, 2018),
date: new Date(),
monthIsOffset: false,
monthOffset: new Date().getMonth(),
yearOffset: new Date().getFullYear()
}
}
render() {
return (
...
)
}
}
calendar.tools.js
let fillCalendar = (month, year) => {
let datesArray = []
let monthStart = new Date(year,month,1).getDay()
let yearType = false;
let filledNodes = 0;
// Check for leap year
(year%4 === 0) ?
(year%100 === 0) ?
(year%400) ? yearType = true : yearType = false :
yearType = true :
yearType = false
const monthArrays = yearType ? [31,29,31,30,31,30,31,31,30,31,30,31] : [31,28,31,30,31,30,31,31,30,31,30,31]
if (month === 0) { month = 12; }
let leadDayStart = monthArrays[month-1] - monthStart + 1
// Loop out lead date numbers
for (let i = 0; i < monthStart; i++) {
datesArray.Push({date: leadDayStart, type: "leadDate", id: "leadDate" + i})
leadDayStart++
filledNodes++
}
if (month === 12) { month = 0; }
// Loop out month's date numbers
for (let i = 0; i < monthArrays[month]; i++) {
datesArray.Push({date: i + 1, type: "monthDate", id: "monthDate" + i})
filledNodes++
}
// fill the empty remaining cells in the calendar
let remainingNodes = 42 - filledNodes;
for (let i = 0; i < remainingNodes; i++) {
datesArray.Push({date: i + 1, type: "postDate", id: "postDate" + i})
}
return datesArray
}
見た目は問題ないので、export
である必要があります。
つかいます
export let fillCalendar = (month, year) => {
の代わりに
let fillCalendar = (month, year) => {
高次コンポーネントの例
来た宣言から関数を直接エクスポート
export default function Authorized(WrappedComponent) {
}