Skip to content

单个定制元素

Item()

单个定制元素,即具体到对应的自定义元素,我们可以获取该元素,从而控制该元素的标题、点击该元素等等。

以【开始 Tab】的按钮为例,我们了解下这个按钮的新增到删除的操作。

新增自定义元素

自定义按钮

6 秒后删除元素

自定义按钮

语法

表达式.CommandBars(CommandBarId).Controls.Item(Index)

表达式:文档类型应用对象

参数

属性数据类型默认值必填说明
Index
Number
第 Index 个定制元素

示例

//@file=base.docx
async function example() {
  await instance.ready()

  const app = instance.Application

  // 定制元素对象【开始 Tab】
  const controls = await app.CommandBars('StartTab').Controls

  // 新增按钮型定制元素
  const controlButton = await controls.Add(1)
  controlButton.Caption = '按钮'

  // 6 秒后删除这个定制元素
  setTimeout(() => {
    controlButton.Delete()
  }, 6000)
}

Caption

通过 Caption 属性,我们可以设置定制元素的标题:

标题

语法

表达式.CommandBars(CommandBarId).Controls.Add(Type).Caption

表达式:文档类型应用对象

示例

//@file=base.docx
async function example() {
  await instance.ready()

  const app = instance.Application

  // 定制元素对象【开始 Tab】
  const controls = await app.CommandBars('StartTab').Controls

  // 添加 1 个定制元素:按钮,并设置标题
  const controlButton = await controls.Add(1)
  controlButton.Caption = '按钮'

  // 添加 1 个定制元素:下拉框,并设置标题
  const controlPopup = await controls.Add(10)
  controlPopup.Caption = '下拉框'
}

Enabled

通过 Enabled 属性的设置,可以禁用定制元素:

禁用

语法

表达式.CommandBars(CommandBarId).Controls.Add(Type).Enabled

表达式:文档类型应用对象

示例

//@file=base.docx
async function example() {
  await instance.ready()

  const app = instance.Application

  // 定制元素对象【开始 Tab】
  const controls = await app.CommandBars('StartTab').Controls

  // 添加 1 个定制元素:按钮,并进行操作
  const controlButton = await controls.Add(1)
  controlButton.Caption = '按钮'
  controlButton.Enabled = false

  // 添加 1 个定制元素:下拉框,并进行操作
  const controlPopup = await controls.Add(10)
  controlPopup.Caption = '下拉框'
  controlPopup.Enabled = false
}

Picture

通过 Picture,我们可以定制元素图标,这里以 Base64 为例,讲解如何设置对应的元素图标:

元素图标

语法

表达式.CommandBars(CommandBarId).Controls.Add(Type).Picture

表达式:文档类型应用对象

示例

//@file=base.docx
async function example() {
  await instance.ready()

  const app = instance.Application

  // 定制元素对象【开始 Tab】
  const controls = await app.CommandBars('StartTab').Controls

  // 添加 1 个定制元素:按钮,并进行操作
  const controlButton = await controls.Add(1)
  controlButton.Caption = '按钮'
  controlButton.Picture =
    ''

  // 添加 1 个定制元素:下拉框,并进行操作
  const controlPopup = await controls.Add(10)
  controlPopup.Caption = '下拉框'
  controlPopup.Picture =
    ''
}

TooltipText

通过 TooltipText,可以设置定制元素的悬浮提示:

给自定义按钮设置悬浮提示

悬浮提示

给自定义下拉框设置悬浮提示

悬浮提示

语法

表达式.CommandBars(CommandBarId).Controls.Add(Type).TooltipText

表达式:文档类型应用对象

示例

//@file=base.docx
async function example() {
  await instance.ready()

  const app = instance.Application

  // 定制元素对象【开始 Tab】
  const controls = await app.CommandBars('StartTab').Controls

  // 添加 1 个定制元素:按钮,并进行操作
  const controlButton = await controls.Add(1)
  controlButton.Caption = '按钮'
  controlButton.TooltipText = '悬浮提示-按钮'

  // 添加 1 个定制元素:下拉框,并进行操作
  const controlPopup = await controls.Add(10)
  controlPopup.Caption = '下拉框'
  controlPopup.TooltipText = '悬浮提示-下拉框'
}

Visible

显示/隐藏定制元素

新增自定义元素

自定义按钮

6 秒后隐藏元素

自定义按钮

语法

表达式.CommandBars(CommandBarId).Controls.Add(Type).Visible

表达式:文档类型应用对象

示例

//@file=base.docx
async function example() {
  await instance.ready()

  const app = instance.Application

  // 定制元素对象【开始 Tab】
  const controls = await app.CommandBars('StartTab').Controls

  // 添加 1 个定制元素:按钮,并进行操作
  const controlButton = await controls.Add(1)
  controlButton.Caption = '按钮'

  // 添加 1 个定制元素:下拉框,并进行操作
  const controlPopup = await controls.Add(10)
  controlPopup.Caption = '下拉框'

  // 6 秒后隐藏定制元素
  setTimeout(() => {
    controlButton.Visible = false
    controlPopup.Visible = false
  }, 6000)
}

With()

可以通过 With(),从而批量设置定制元素属性,具体的各个属性的使用,可以参考单个属性的设置。

语法

表达式.CommandBars(CommandBarId).Controls.Add(Type).With(Properties)

表达式:文档类型应用对象

参数

属性数据类型默认值必填说明
Caption
String
标题
Enabled
Boolean
是否禁用
Picture
String
图标
Visible
Boolean
显示/隐藏
TooltipText
String
悬浮提示

示例

//@file=base.docx
async function example() {
  await instance.ready()

  const app = instance.Application

  // 定制元素对象【开始 Tab】
  const controls = await app.CommandBars('StartTab').Controls

  // 添加 1 个定制元素:按钮,并进行操作
  const controlButton = await controls.Add(1)
  controlButton.With({
    Caption: 按钮,
    Enabled: false
  })

  // 添加 1 个定制元素:下拉框,并进行操作
  const controlPopup = await controls.Add(10)
  controlPopup.With({
    Caption: '下拉框',
    Enabled: false
  })
}

Delete()

通过 Delete() 方法,可以删除定制元素:

新增自定义元素

自定义按钮

6 秒后删除元素

自定义按钮

语法

表达式.CommandBars(CommandBarId).Controls.Add(Type).Delete()

表达式:文档类型应用对象

示例

//@file=base.docx
async function example() {
  await instance.ready()

  const app = instance.Application

  // 定制元素对象【开始 Tab】
  const controls = await app.CommandBars('StartTab').Controls

  // 添加 1 个定制元素:按钮,并设置标题
  const controlButton = await controls.Add(1)
  controlButton.Caption = '按钮'

  // 添加 1 个定制元素:下拉框,并设置标题
  const controlPopup = await controls.Add(10)
  controlPopup.Caption = '下拉框'

  // 6 秒后删除这 2 个定制元素
  setTimeout(() => {
    controlButton.Delete()
    controlPopup.Delete()
  }, 6000)
}

Execute()

通过 Execute() 方法,可以点击定制元素。

当然,配合 OnAction() 这个监听事件,可以得知按钮是否被点击了。

语法

表达式.CommandBars(CommandBarId).Controls.Add(Type).Execute()

表达式:文档类型应用对象

示例

//@file=base.docx
async function example() {
  await instance.ready()

  const app = instance.Application

  // 定制元素对象【开始 Tab】
  const controls = await app.CommandBars('StartTab').Controls

  // 添加 1 个定制元素:按钮,并进行操作
  const controlButton = await controls.Add(1)
  controlButton.Caption = '按钮'
  controlButton.OnAction = () => console.log('按钮点击了')

  // 添加 1 个定制元素:下拉框,并进行操作
  const controlPopup = await controls.Add(10)
  controlPopup.Caption = '下拉框'
  controlPopup.OnAction = () => console.log('下拉框点击了')

  // 6 秒后执行点击操作
  setTimeout(async () => {
    await controlButton.Execute()
    await controlPopup.Execute()
  }, 6000)
}

SetFocus()

聚焦定制元素,即通过 SetFocus 将光标聚集到对应位置:

聚焦

语法

表达式.CommandBars(CommandBarId).Controls.Add(Type).SetFocus()

表达式:文档类型应用对象

示例

//@file=base.docx
async function example() {
  await instance.ready()

  const app = instance.Application

  // 定制元素对象【开始 Tab】
  const controls = await app.CommandBars('StartTab').Controls

  // 添加 1 个定制元素:按钮,并进行操作
  const controlButton = await controls.Add(1)
  controlButton.Caption = '按钮'
  await controlButton.SetFocus()

  // 添加 1 个定制元素:下拉框,并进行操作
  const controlPopup = await controls.Add(10)
  controlPopup.Caption = '下拉框'
  await controlPopup.SetFocus()
}

OnAction()

监听定制元素点击事件,设置之后,只要按钮被点击,就可以通过控制台查看到对应的信息,从而制定相关的业务。

语法

表达式.CommandBars(CommandBarId).Controls.Add(Type).OnAction() = Function

表达式:文档类型应用对象

示例

//@file=base.docx
async function example() {
  await instance.ready()

  const app = instance.Application

  // 定制元素对象【开始 Tab】
  const controls = await app.CommandBars('StartTab').Controls

  // 添加 1 个定制元素:按钮,并进行操作
  const controlButton = await controls.Add(1)
  controlButton.Caption = '按钮'
  controlButton.OnAction = () => console.log('按钮点击了')

  // 添加 1 个定制元素:下拉框,并进行操作
  const controlPopup = await controls.Add(10)
  controlPopup.Caption = '下拉框'
  controlPopup.OnAction = () => console.log('下拉框点击了')
}