getCSSProperty
从给定选择器选择的 DOM 元素获取 CSS 属性。返回值被格式化为可测试的。颜色通过rgb2hex解析,所有其他属性通过css-value解析。
信息
请注意,简写 CSS 属性(例如 background
、font
、border
、margin
、padding
、list-style
、outline
、pause
、cue
)将被展开以获取所有完整属性,从而导致多个 WebDriver 调用。如果您对特定完整属性感兴趣,建议改为查询该属性。
用法
$(selector).getCSSProperty(cssProperty, pseudoElement)
参数
名称 | 类型 | 详情 |
---|---|---|
cssProperty | 字符串 | css 属性名称 |
pseudoElement | 伪元素 | css 伪元素 |
示例
example.html
<label id="myLabel" for="input" style="color: #0088cc; font-family: helvetica, arial, freesans, clean, sans-serif, width: 100px">Some Label</label>
getCSSProperty.js
it('should demonstrate the getCSSProperty command', async () => {
const elem = await $('#myLabel')
const color = await elem.getCSSProperty('color')
console.log(color)
// outputs the following:
// {
// property: 'color',
// value: 'rgba(0, 136, 204, 1)',
// parsed: {
// hex: '#0088cc',
// alpha: 1,
// type: 'color',
// rgba: 'rgba(0, 136, 204, 1)'
// }
// }
const font = await elem.getCSSProperty('font-family')
console.log(font)
// outputs the following:
// {
// property: 'font-family',
// value: 'helvetica',
// parsed: {
// value: [ 'helvetica', 'arial', 'freesans', 'clean', 'sans-serif' ],
// type: 'font',
// string: 'helvetica, arial, freesans, clean, sans-serif'
// }
// }
var width = await elem.getCSSProperty('width', '::before')
console.log(width)
// outputs the following:
// {
// property: 'width',
// value: '100px',
// parsed: {
// type: 'number',
// string: '100px',
// unit: 'px',
// value: 100
// }
// }
})