如何在 mwc 文本字段中为高度添加 mixin?
How to add mixin for height in mwc textfield?
我正在使用聚合物 3 和 lit-element(2.2.1)。 mwc-textfield 的版本是 0.13.0。我已经阅读了与此 version.In 此 documentation 相关的文档,我发现我们可以为高度添加 mixin。我尝试了几种方法但没有成功。可能是我使用的语法错误。我想降低文本字段的高度。这是我的文本字段
<mwc-textfield id="textBox" .type="text" .value=${this.title} .placeholder='' minLength="10" maxLength="256"></mwc-textfield>
和我的 css
#textBox{
text-transform: none;
--mdc-theme-primary: transparent;
--mdc-text-field-fill-color: #fff;
--mdc-text-field-hover-line-color: #f5f5f5;
--mwc-text-width: 100%;
width:100%;
}
应用的默认 css 是
:host(:not([disabled])) .mdc-text-field:not(.mdc-text-field--outlined) {
background-color: transparent;
}
.mdc-text-field:not(.mdc-text-field--disabled) {
background-color: rgb(245, 245, 245);
}
.mdc-text-field {
display: flex;
width: 100%;
}
.mdc-text-field {
height: 56px;
display: inline-flex;
position: relative;
box-sizing: border-box;
will-change: opacity, transform, color;
border-radius: 4px 4px 0px 0px;
overflow: hidden;
}
.mdc-text-field {
--mdc-ripple-fg-size: 0;
--mdc-ripple-left: 0;
--mdc-ripple-top: 0;
--mdc-ripple-fg-scale: 1;
--mdc-ripple-fg-translate-end: 0;
--mdc-ripple-fg-translate-start: 0;
-webkit-tap-highlight-color: rgba(0, 0, 0, 0);
}
user agent stylesheet
label {
cursor: default;
}
<style>
#textfield {
width: var(--text-field-width,80%);
height: 100%;
position: absolute;
left: 0;
top: -12px;
text-transform: capitalize;
--mwc-text-width: 100%;
}
<style>
mwc-textfield {
--mdc-theme-primary: transparent;
--mdc-text-field-ink-color: black;
--mdc-text-field-fill-color: transparent;
--mdc-text-field-disabled-fill-color: transparent;
}
应用于文本字段的默认高度为 56 像素。我试过的是
#textbox.mdc-text-field--height{
height:45px;
}
和
#textbox.mdc-text-field--height('45px');
并且还在节点模块文件中添加了 mixin 作为 height:var(--mdc-text-field-height,56px);
并在 css 中用作
#textBox{
--mdc-text-field-height:45px;
}
如有任何帮助,我们将不胜感激!提前致谢。
Material 设计组件与 Material 网络组件
I have read the documentations related to this version. In this documentation, I have found that we can add mixin for height.
这里首先要注意的是 material 组件有两个不同的库:您所指的是 MDC(Material 设计组件,在 npm 上作为 @material/<component>
) 这是 SASS+JS 实现的 Material 组件。另一个是 MWC(Material Web Components,分布为 @material/mwc-<component>
),基于前一个库的实际 WebComponents 集合。因此请记住,该文档指的是您实际使用的 MWC 组件的 MDC 副本 (<mwc-textfield>
)。
外观造型
你想在这里做什么
#textbox.mdc-text-field--height {
height: 45px;
}
不起作用主要是因为无法在自定义元素的影子根内进行选择(至少,);另外,负责高度的元素是 <label>
,其 class 是 .mdc-text-field
.
querySelector方式
我想到的改变身高最快的方法是:
import { LitElement, html, property, customElement, css, query } from 'lit-element';
import '@material/mwc-textfield';
@customElement('my-component')
export class MyComponent extends LitElement {
// Select the text field
@query('mwc-textfield') textField;
async firstUpdated() {
// Wait for its dom to be ready
await this.textField.updateComplete;
// Programmatically select the label
// and change the height
this.textField
.shadowRoot
.querySelector('.mdc-text-field')
.style
.height = '45px';
}
render() {
return html`<mwc-textfield></mwc-textfield>`;
}
}
但是我 真的 不推荐它:抛开性能和优雅不谈,它可能会破坏某些 mwc-textfield
功能,例如浮动标签。
扩展方式
您还可以通过扩展 TextField
和覆盖样式来强制高度:
import {LitElement, html, customElement, css} from 'lit-element';
import {TextField} from '@material/mwc-textfield/mwc-textfield';
@customElement('my-textfield')
export class MyTextfield extends TextField {
static styles = [TextField.styles, css`
.mdc-text-field {
height: 45px;
}
`];
}
// Then use <my-textfield> instead of <mwc-textfield>
但同样,与上述一样,使用风险自负...
使用mixin
我想现在使用 height
mixin 的唯一方法是构建一个自定义版本的 TextField,它或多或少是这样的:
- 克隆 mwc repo(是的,它是一个 monorepo,因此您也可以获得所有其他组件,但我很确定您可以删除所有未由 mwc-textfield 导入的组件)
- npm 安装
- 在
packages/mwc-textfield/src/mwc-textfield.scss
中使用mixin:
@include mixins.height(45px);
大概在 here 左右
- npm 运行 构建
- 复制 mwc-textfield 文件夹并将其粘贴到您的项目中(删除源文件,npm pack 可能对此很方便),然后将导入从
@material/mwc-textfield
更改为 ./path/to/custom-textfield
当然,改变高度的工作太多了...好消息是 MWC 仍在开发中,不能排除他们会添加 CSS 自定义 属性 或其他一些自定义高度的方法。此外,新的 density 概念正在 MWC 中实现(遗憾的是尚未在 TextField 中实现),这可能正是您所需要的。
关于这个也有公开issue,看看他们怎么说
我正在使用聚合物 3 和 lit-element(2.2.1)。 mwc-textfield 的版本是 0.13.0。我已经阅读了与此 version.In 此 documentation 相关的文档,我发现我们可以为高度添加 mixin。我尝试了几种方法但没有成功。可能是我使用的语法错误。我想降低文本字段的高度。这是我的文本字段
<mwc-textfield id="textBox" .type="text" .value=${this.title} .placeholder='' minLength="10" maxLength="256"></mwc-textfield>
和我的 css
#textBox{
text-transform: none;
--mdc-theme-primary: transparent;
--mdc-text-field-fill-color: #fff;
--mdc-text-field-hover-line-color: #f5f5f5;
--mwc-text-width: 100%;
width:100%;
}
应用的默认 css 是
:host(:not([disabled])) .mdc-text-field:not(.mdc-text-field--outlined) {
background-color: transparent;
}
.mdc-text-field:not(.mdc-text-field--disabled) {
background-color: rgb(245, 245, 245);
}
.mdc-text-field {
display: flex;
width: 100%;
}
.mdc-text-field {
height: 56px;
display: inline-flex;
position: relative;
box-sizing: border-box;
will-change: opacity, transform, color;
border-radius: 4px 4px 0px 0px;
overflow: hidden;
}
.mdc-text-field {
--mdc-ripple-fg-size: 0;
--mdc-ripple-left: 0;
--mdc-ripple-top: 0;
--mdc-ripple-fg-scale: 1;
--mdc-ripple-fg-translate-end: 0;
--mdc-ripple-fg-translate-start: 0;
-webkit-tap-highlight-color: rgba(0, 0, 0, 0);
}
user agent stylesheet
label {
cursor: default;
}
<style>
#textfield {
width: var(--text-field-width,80%);
height: 100%;
position: absolute;
left: 0;
top: -12px;
text-transform: capitalize;
--mwc-text-width: 100%;
}
<style>
mwc-textfield {
--mdc-theme-primary: transparent;
--mdc-text-field-ink-color: black;
--mdc-text-field-fill-color: transparent;
--mdc-text-field-disabled-fill-color: transparent;
}
应用于文本字段的默认高度为 56 像素。我试过的是
#textbox.mdc-text-field--height{
height:45px;
}
和
#textbox.mdc-text-field--height('45px');
并且还在节点模块文件中添加了 mixin 作为 height:var(--mdc-text-field-height,56px); 并在 css 中用作
#textBox{
--mdc-text-field-height:45px;
}
如有任何帮助,我们将不胜感激!提前致谢。
Material 设计组件与 Material 网络组件
I have read the documentations related to this version. In this documentation, I have found that we can add mixin for height.
这里首先要注意的是 material 组件有两个不同的库:您所指的是 MDC(Material 设计组件,在 npm 上作为 @material/<component>
) 这是 SASS+JS 实现的 Material 组件。另一个是 MWC(Material Web Components,分布为 @material/mwc-<component>
),基于前一个库的实际 WebComponents 集合。因此请记住,该文档指的是您实际使用的 MWC 组件的 MDC 副本 (<mwc-textfield>
)。
外观造型
你想在这里做什么
#textbox.mdc-text-field--height {
height: 45px;
}
不起作用主要是因为无法在自定义元素的影子根内进行选择(至少,<label>
,其 class 是 .mdc-text-field
.
querySelector方式
我想到的改变身高最快的方法是:
import { LitElement, html, property, customElement, css, query } from 'lit-element';
import '@material/mwc-textfield';
@customElement('my-component')
export class MyComponent extends LitElement {
// Select the text field
@query('mwc-textfield') textField;
async firstUpdated() {
// Wait for its dom to be ready
await this.textField.updateComplete;
// Programmatically select the label
// and change the height
this.textField
.shadowRoot
.querySelector('.mdc-text-field')
.style
.height = '45px';
}
render() {
return html`<mwc-textfield></mwc-textfield>`;
}
}
但是我 真的 不推荐它:抛开性能和优雅不谈,它可能会破坏某些 mwc-textfield
功能,例如浮动标签。
扩展方式
您还可以通过扩展 TextField
和覆盖样式来强制高度:
import {LitElement, html, customElement, css} from 'lit-element';
import {TextField} from '@material/mwc-textfield/mwc-textfield';
@customElement('my-textfield')
export class MyTextfield extends TextField {
static styles = [TextField.styles, css`
.mdc-text-field {
height: 45px;
}
`];
}
// Then use <my-textfield> instead of <mwc-textfield>
但同样,与上述一样,使用风险自负...
使用mixin
我想现在使用 height
mixin 的唯一方法是构建一个自定义版本的 TextField,它或多或少是这样的:
- 克隆 mwc repo(是的,它是一个 monorepo,因此您也可以获得所有其他组件,但我很确定您可以删除所有未由 mwc-textfield 导入的组件)
- npm 安装
- 在
packages/mwc-textfield/src/mwc-textfield.scss
中使用mixin:
大概在 here@include mixins.height(45px);
左右
- npm 运行 构建
- 复制 mwc-textfield 文件夹并将其粘贴到您的项目中(删除源文件,npm pack 可能对此很方便),然后将导入从
@material/mwc-textfield
更改为./path/to/custom-textfield
当然,改变高度的工作太多了...好消息是 MWC 仍在开发中,不能排除他们会添加 CSS 自定义 属性 或其他一些自定义高度的方法。此外,新的 density 概念正在 MWC 中实现(遗憾的是尚未在 TextField 中实现),这可能正是您所需要的。
关于这个也有公开issue,看看他们怎么说