首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >在现代页面上使用带有SPFx webpart的office-ui-fabric面板时出现问题

在现代页面上使用带有SPFx webpart的office-ui-fabric面板时出现问题
EN

Stack Overflow用户
提问于 2020-06-29 22:48:54
回答 2查看 629关注 0票数 0

我编写了一个基于react的the部件,它使用Office UI Fabric React panel组件在屏幕右侧显示一个面板。The部件在工作台中运行良好。

但是,当将其部署到现代页面时,面板会呈现在webpart container.Thus中,显示在页面内部,而不是屏幕的右侧。

Workbench Result

Page Result

在React组件的render方法中,我这样做:

代码语言:javascript
复制
public render(): React.ReactElement<IMyTasksProps> {
return (
  <div className={ styles.myTasks } >

    {
      this.state.loading &&
      <div className={ styles.container }>
        <div className={ styles.row }>
          <div className={styles.columnLoadingContent}>
            <Spinner size={SpinnerSize.large} />
          </div>
        </div>
      </div>
    }

    { !this.state.loading &&

      <div className={ styles.container }>
        <div className={ styles.row } onClick={this.onWebPartClick.bind(this)}>
          <div className={styles.columnMainIcon}>
            <Icon iconName="CheckList" className={iconClass} />
          </div>
          <div className={ this.state.myTaskItems.reduce((totalOpenTasks, taskItem) => totalOpenTasks + taskItem.props.openTasks, 0) == 0 ? styles.circleGreen : styles.circleRed }>{this.state.myTaskItems.reduce((totalOpenTasks, taskItem) => totalOpenTasks + taskItem.props.openTasks, 0)}</div>
          <div className={ styles.columnMainContent }>{escape(this.props.description)}</div>
          <div className={ styles.columnMainIcon }>
            <Icon iconName="ChromeBackMirrored" className={iconClass} />
          </div>
        </div>
        <div>
          <Panel type={PanelType.custom} customWidth="400px" isOpen={this.state.isOpen} onDismiss={this.onPanelClosed.bind(this)} >
            <h3>{escape(this.props.description)}</h3>
            <div className={ styles.myTasks } >
              <div className={ styles.taskContainer}>
                { this.state.myTaskItems
                    .sort((a,b) => (a.props.header > b.props.header) ? 1 : ((b.props.header > a.props.header) ? -1 : 0))
                    .map(taskItem => taskItem.render())
                }
              </div>
            </div>
          </Panel>
        </div>
      </div>
    }
  </div>
);

}

对于导致这种行为的原因有什么建议吗?

提前谢谢。

EN

回答 2

Stack Overflow用户

发布于 2020-06-30 17:37:56

在包解决方案中,domainisolated被设置为true,这当然会在iframe中呈现web部件。这就解释了奇怪的行为。现在工作起来像个护身符。

票数 1
EN

Stack Overflow用户

发布于 2020-06-30 09:41:33

您使用的是office fabric ui panel

当我在我的环境中测试时,运行良好。

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/62640729

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档