簡體   English   中英

SPFX React -Basic Webpart 中的數據版本錯誤

[英]Data version error in SPFX React -Basic Webpart

我剛剛創建了一個帶有反應但出現以下錯誤的基本 spfx webpart:

{ "resource": "/c:/Node_Dev/CRUD_React/src/webparts/crudReact001/CrudReact001WebPart.ts", "owner": "typescript", "code": "2611", "severity": 8, "message" : "'dataVersion' 在 class 'BaseClientSideWebPart' 中被定義為一個屬性,但在 'CrudReact001WebPart' 中作為訪問器被覆蓋。", "source": "ts", "startLineNumber": 35, "startColumn": 17, “endLineNumber”:35,“endColumn”:28}

我的代碼:

import * as React from 'react';
import * as ReactDom from 'react-dom';
import { Version } from '@microsoft/sp-core-library';
import {
  IPropertyPaneConfiguration,
  PropertyPaneTextField
} from '@microsoft/sp-property-pane';
import { BaseClientSideWebPart } from '@microsoft/sp-webpart-base';

import * as strings from 'CrudReact001WebPartStrings';
import CrudReact001 from './components/CrudReact001';
import { ICrudReact001Props } from './components/ICrudReact001Props';

export interface ICrudReact001WebPartProps {
  description: string;
}

export default class CrudReact001WebPart extends BaseClientSideWebPart<ICrudReact001WebPartProps> {

  public render(): void {
    const element: React.ReactElement<ICrudReact001Props> = React.createElement(
      CrudReact001,
      {
        description: this.properties.description
      }
    );

    ReactDom.render(element, this.domElement);
  }

  protected onDispose(): void {
    ReactDom.unmountComponentAtNode(this.domElement);
  }

  protected get dataVersion(): Version {
    return Version.parse('1.0');
  }

  protected getPropertyPaneConfiguration(): IPropertyPaneConfiguration {
    return {
      pages: [
        {
          header: {
            description: strings.PropertyPaneDescription
          },
          groups: [
            {
              groupName: strings.BasicGroupName,
              groupFields: [
                PropertyPaneTextField('description', {
                  label: strings.DescriptionFieldLabel
                })
              ]
            }
          ]
        }
      ]
    };
  }
}

下面鏈接的文章提供了有關該問題的更多詳細信息:

https://dreamsof.dev/2020-09-21-typescript-upgrade-breaking-dataversion-get-override-spfx11/

建議的解決方案是:

  1. 使用工作區版本 TypeScript (3.3.4000) 而不是 VS Code 的更新版本
  2. // @ts-ignore裝飾方法

您可以只刪除'datavaersion' 方法,它與SPFx v1.10 兼容,但在安裝V1.11 時會出錯。

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM