使用SharePoint Framework开发webpart的一些技巧汇总

1, 为你的webpart指定一个图标

在创建一个webpart的时候,SPFx会使用一个默认图标,如下所示:

使用SharePoint Framework开发webpart的一些技巧汇总_第1张图片

这个图标是在manifest文件中 ,通过officeFabricIconFontName属性指定的,默认的值是“Page”,所以我们看到的是一个页面的图标。

"preconfiguredEntries": [{
    "groupId": "5c03119e-3074-46fd-976b-c60198311f70", // Other
    "group": { "default": "Other" },
    "title": { "default": "WebpartTips" },
    "description": { "default": "WebpartTips description" },
    "officeFabricIconFontName": "Page",
    "properties": {
      "description": "WebpartTips"
    }
  }]

可以修改这个属性的值,换成其他图标,例如“Calendar”,重新启动gulp serve,就可以看到新图标:

使用SharePoint Framework开发webpart的一些技巧汇总_第2张图片

所有可以使用的fabric图标,可以参考:https://developer.microsoft.com/en-us/fabric#/styles/icons

如果希望使用自定义的图标,需要删除“officeFabricIconFontName”这个属性,添加另一个属性“iconImageUrl”,因为officeFabricIconFontName会覆盖iconImageUrl这个属性。iconImageUrl的值可以是图片的url,也可以是base64编码的图片:

"preconfiguredEntries": [{
    "groupId": "5c03119e-3074-46fd-976b-c60198311f70", // Other
    "group": { "default": "Other" },
    "title": { "default": "WebpartTips" },
    "description": { "default": "WebpartTips description" },
    "iconImageUrl": "",
    "properties": {
      "description": "WebpartTips"
    }
  }]

效果如下:

使用SharePoint Framework开发webpart的一些技巧汇总_第3张图片

2,隐藏webpart

在manifest文件中,通过指定hiddenFromToolbox的值为true,可以隐藏一个webpart:

使用SharePoint Framework开发webpart的一些技巧汇总_第4张图片

这样用户在页面上添加一个webpart的时候,你的webpart不会被列出来:

使用SharePoint Framework开发webpart的一些技巧汇总_第5张图片

3,提示用户配置webpart

很多情况下,一个webpart需要配置才可以使用。这里推荐一个pnp控件:Placeholder Control

可以在用户添加webpart之后,立即提示用户配置webpart:

使用SharePoint Framework开发webpart的一些技巧汇总_第6张图片

首先安装pnp控件:

使用SharePoint Framework开发webpart的一些技巧汇总_第7张图片

然后在webpart ts文件中导入react,react dom以及Placeholder控件:

import * as React from 'react';
import * as ReactDom from 'react-dom';
import { Placeholder } from "@pnp/spfx-controls-react/lib/Placeholder";

修改render方法,显示placeholder控件:

export default class WebpartTipsWebPart extends BaseClientSideWebPart {
  
  public render(): void {
    ReactDom.render(React.createElement(Placeholder, {
             iconName:'Edit',
             iconText:'请配置web part',
             description:'点击按钮配置web part',
             buttonLabel:'配置',
             onConfigure: this.onConfigure.bind(this)
    }), this.domElement);
  
  }

  private onConfigure() {
    this.context.propertyPane.open();
  }

 。。。

4, 改变webpart属性面板的布局

默认情况下,webpart属性面板中的组Group是顺序展示的,例如Group 1,然后Group 2,每个组中包含配置项:

 

使用SharePoint Framework开发webpart的一些技巧汇总_第8张图片

但是如果一个组中的配置项比较多,最好可以将组折叠起来就像这样:

使用SharePoint Framework开发webpart的一些技巧汇总_第9张图片

这是在”getPropertyPaneConfiguration“方法中,指定“displayGroupsAsAccordion“属性来实现的,这个属性为true,表示组折叠起来展示,默认情况下所有的组都是折叠的。如果希望某个组默认是展开的,可以在组的配置中指定“isCollapsed”属性为false,上面的例子中,Group 1的“isCollapsed”属性为true,Group 2的“isCollapsed”属性为false

protected getPropertyPaneConfiguration(): IPropertyPaneConfiguration {
    return {
      pages: [
        {
          header: {
            description: strings.PropertyPaneDescription
          },
          displayGroupsAsAccordion: true, //指定为true,折叠组的配置项
          groups: [
            {
              groupName: 'Group 1',
              groupFields: [
                PropertyPaneTextField('description', {
                  label: 'Field in Group 1'
                })
              ],
              isCollapsed:true    //指定组是否是折叠的
            },
            {
              groupName: 'Group 2',
              groupFields: [
                PropertyPaneTextField('description', {
                  label: 'Field in Group 2'
                })
              ],
              isCollapsed: false
            }
          ]
        }
      ]
    };
  }

 5, 分页显示Webpart属性面板

”getPropertyPaneConfiguration“方法返回值包含了pages数组,在pages数组中添加新的page,可以分页显示属性:

protected getPropertyPaneConfiguration(): IPropertyPaneConfiguration {
    return {
      pages: [
        {
          header: {
            description: strings.PropertyPaneDescription
          },
          groups: [
            {
              groupName: strings.BasicGroupName,
              groupFields: [
                PropertyPaneTextField('description', {
                  label: strings.DescriptionFieldLabel
                })
              ]
            }
          ]
        },
        { //这里添加了一个page
          header: {
            description: strings.PropertyPaneDescription
          },
          groups: [
            {
              groupName: strings.BasicGroupName,
              groupFields: [
                PropertyPaneTextField('description', {
                  label: strings.DescriptionFieldLabel
                })
              ]
            }
          ]
        }
      ]
    };
  }

 效果如图:

使用SharePoint Framework开发webpart的一些技巧汇总_第10张图片

6,在manifest.json文件中指定属性的初始值

使用SharePoint Framework开发webpart的一些技巧汇总_第11张图片

第一次打开属性编辑面板中默认显示初始值:

使用SharePoint Framework开发webpart的一些技巧汇总_第12张图片

 

你可能感兴趣的:(TypeScript,Office,365开发,SharePoint,Framework,SharePoint,Framework)