跳过主内容
版本:v8

CSS 工具类

Ionic Framework 提供了一组 CSS 工具类,可以用于任何元素,以修改文本、元素位置或调整填充和边距。

注意

如果你的应用不是使用可用的 Ionic Framework 启动器启动的,则需要在全局样式表中包含可选部分中列出的样式表,才能使这些样式生效。

文本修改

文本对齐

<ion-grid>
<ion-row>
<ion-col>
<div class="ion-text-start">
<h3>text-start</h3>
Lorem ipsum dolor sit amet, consectetur adipiscing elit. Sed ac vehicula lorem.
</div>
</ion-col>
<ion-col>
<div class="ion-text-end">
<h3>text-end</h3>
Lorem ipsum dolor sit amet, consectetur adipiscing elit. Sed ac vehicula lorem.
</div>
</ion-col>
<ion-col>
<div class="ion-text-center">
<h3>text-center</h3>
Lorem ipsum dolor sit amet, consectetur adipiscing elit. Sed ac vehicula lorem.
</div>
</ion-col>
</ion-row>
<ion-row>
<ion-col>
<div class="ion-text-justify">
<h3>text-justify</h3>
Lorem ipsum dolor sit amet, consectetur adipiscing elit. Sed ac vehicula lorem.
</div>
</ion-col>
<ion-col>
<div class="ion-text-wrap">
<h3>text-wrap</h3>
Lorem ipsum dolor sit amet, consectetur adipiscing elit. Sed ac vehicula lorem.
</div>
</ion-col>
<ion-col>
<div class="ion-text-nowrap">
<h3>text-nowrap</h3>
Lorem ipsum dolor sit amet, consectetur adipiscing elit.
</div>
</ion-col>
</ion-row>
</ion-grid>
样式规则描述
.ion-text-lefttext-align: left行内内容与行框的左边缘对齐。
.ion-text-righttext-align: right行内内容与行框的右边缘对齐。
.ion-text-starttext-align: start如果方向是从左到右,则与 text-left 相同;如果方向是从右到左,则与 text-right 相同。
.ion-text-endtext-align: end如果方向是从左到右,则与 text-right 相同;如果方向是从右到左,则与 text-left 相同。
.ion-text-centertext-align: center行内内容在行框内居中。
.ion-text-justifytext-align: justify行内内容对齐。文本应间距以使其左右边缘与行框的左右边缘对齐,但最后一行除外。
.ion-text-wrapwhite-space: normal空白字符序列将被折叠。源代码中的换行符将被视为其他空白字符。根据需要换行以填充行框。
.ion-text-nowrapwhite-space: nowrapnormal 相同折叠空白字符,但会抑制文本中的换行(文本换行)。

文本转换

<ion-grid>
<ion-row>
<ion-col>
<div class="ion-text-uppercase">
<h3>text-uppercase</h3>
Lorem ipsum dolor sit amet, consectetur adipiscing elit. Sed ac vehicula lorem.
</div>
</ion-col>
<ion-col>
<div class="ion-text-lowercase">
<h3>text-lowercase</h3>
Lorem ipsum dolor sit amet, consectetur adipiscing elit. Sed ac vehicula lorem.
</div>
</ion-col>
<ion-col>
<div class="ion-text-capitalize">
<h3>text-capitalize</h3>
Lorem ipsum dolor sit amet, consectetur adipiscing elit. Sed ac vehicula lorem.
</div>
</ion-col>
</ion-row>
</ion-grid>
样式规则描述
.ion-text-uppercasetext-transform: uppercase强制所有字符转换为大写。
.ion-text-lowercasetext-transform: lowercase强制所有字符转换为小写。
.ion-text-capitalizetext-transform: capitalize强制每个单词的首字母转换为大写。

响应式文本类

上面列出的所有文本类都有一些额外的类,可以根据屏幕尺寸修改文本。不要使用每个类中的 text-,而是使用 text-{breakpoint}- 在特定屏幕尺寸上使用该类,其中 {breakpoint}Ionic 断点 中列出的断点名称之一。

下表显示了默认行为,其中 {modifier} 是以下任何一项:leftrightstartendcenterjustifywrapnowrapuppercaselowercasecapitalize,如上所述。

描述
.ion-text-{modifier}在所有屏幕尺寸上将修饰符应用于元素。
.ion-text-sm-{modifier}min-width: 576px 时,将修饰符应用于元素。
.ion-text-md-{modifier}min-width: 768px 时,将修饰符应用于元素。
.ion-text-lg-{modifier}min-width: 992px 时,将修饰符应用于元素。
.ion-text-xl-{modifier}min-width: 1200px 时,将修饰符应用于元素。

元素放置

浮动元素

float CSS 属性指定元素应放置在其容器的左侧或右侧,文本和行内元素将在其周围环绕。这样,元素将从网页的正常流程中移除,但仍是流程的一部分,与绝对定位相反。

<ion-grid>
<ion-row>
<ion-col>
<h3>no float</h3>
<img
alt="Silhouette of a person's head"
src="https://ionicframework.cn/docs/img/demos/avatar.svg"
height="50px"
/>
Lorem ipsum dolor sit amet, consectetur adipiscing elit. Sed ac vehicula lorem.
</ion-col>
<ion-col>
<h3>float-left</h3>
<img
alt="Silhouette of a person's head"
src="https://ionicframework.cn/docs/img/demos/avatar.svg"
height="50px"
class="ion-float-left"
/>
Lorem ipsum dolor sit amet, consectetur adipiscing elit. Sed ac vehicula lorem.
</ion-col>
<ion-col>
<h3>float-right</h3>
<img
alt="Silhouette of a person's head"
src="https://ionicframework.cn/docs/img/demos/avatar.svg"
height="50px"
class="ion-float-right"
/>
Lorem ipsum dolor sit amet, consectetur adipiscing elit. Sed ac vehicula lorem.
</ion-col>
</ion-row>
</ion-grid>
样式规则描述
.ion-float-leftfloat: left元素将浮动在其包含块的左侧。
.ion-float-rightfloat: right元素将浮动在其包含块的右侧。
.ion-float-startfloat: left / float: right如果方向是从左到右,则与 float-left 相同;如果方向是从右到左,则与 float-right 相同。
.ion-float-endfloat: left / float: right如果方向是从左到右,则与 float-right 相同;如果方向是从右到左,则与 float-left 相同。

响应式浮动类

上面列出的所有浮动类都有一些额外的类,可以根据屏幕尺寸修改浮动。不要使用每个类中的 float-,而是使用 float-{breakpoint}- 在特定屏幕尺寸上使用该类,其中 {breakpoint}Ionic 断点 中列出的断点名称之一。

下表显示了默认行为,其中 {modifier} 是以下任何一项:leftrightstartend,如上所述。

描述
.ion-float-{modifier}在所有屏幕尺寸上将修饰符应用于元素。
.ion-float-sm-{modifier}min-width: 576px 时,将修饰符应用于元素。
.ion-float-md-{modifier}min-width: 768px 时,将修饰符应用于元素。
.ion-float-lg-{modifier}min-width: 992px 时,将修饰符应用于元素。
.ion-float-xl-{modifier}min-width: 1200px 时,将修饰符应用于元素。

元素显示

display CSS 属性确定元素是否应该可见。如果元素被隐藏,它将仍然在 DOM 中,但不会被渲染。

<ion-grid>
<ion-row>
<ion-col class="ion-hide">
<div>
<h3>hidden</h3>
You can't see me.
</div>
</ion-col>
<ion-col>
<div>
<h3>not-hidden</h3>
You can see me!
</div>
</ion-col>
</ion-row>
</ion-grid>
样式规则描述
.ion-hidedisplay: none元素将被隐藏。

响应式显示属性

还有一些额外的类可以根据屏幕尺寸修改可见性。不要只是使用 .ion-hide 用于所有屏幕尺寸,而是使用 .ion-hide-{breakpoint}-{dir} 在特定屏幕尺寸上使用该类,其中 {breakpoint}Ionic 断点 中列出的断点名称之一,而 {dir} 则表示元素应该在所有屏幕尺寸上隐藏(up)或在指定的断点以下(down)隐藏。

描述
.ion-hide-sm-{dir}min-width: 576pxup)或 max-width: 576pxdown)时,将修饰符应用于元素。
.ion-hide-md-{dir}min-width: 768pxup)或 max-width: 768pxdown)时,将修饰符应用于元素。
.ion-hide-lg-{dir}min-width: 992pxup)或 max-width: 992pxdown)时,将修饰符应用于元素。
.ion-hide-xl-{dir}min-width: 1200pxup)或 max-width: 1200pxdown)时,将修饰符应用于元素。

内容空间

元素填充

padding 类设置元素的填充区域。填充区域是元素内容与其边框之间的空间。

默认情况下,将应用的 padding16px,由 --ion-padding 变量设置。有关如何更改这些值的更多信息,请参阅 CSS 变量 部分。

<ion-grid>
<ion-row>
<ion-col class="ion-padding">
<div>padding</div>
</ion-col>
<ion-col class="ion-padding-top">
<div>padding-top</div>
</ion-col>
<ion-col class="ion-padding-start">
<div>padding-start</div>
</ion-col>
<ion-col class="ion-padding-end">
<div>padding-end</div>
</ion-col>
</ion-row>
<ion-row>
<ion-col class="ion-padding-bottom">
<div>padding-bottom</div>
</ion-col>
<ion-col class="ion-padding-vertical">
<div>padding-vertical</div>
</ion-col>
<ion-col class="ion-padding-horizontal">
<div>padding-horizontal</div>
</ion-col>
<ion-col class="ion-no-padding">
<div>no-padding</div>
</ion-col>
</ion-row>
</ion-grid>
样式规则描述
.ion-paddingpadding: 16px应用于所有边的填充。
.ion-padding-toppadding-top: 16px应用于顶部的填充。
.ion-padding-startpadding-start: 16px应用于开始处的填充。
.ion-padding-endpadding-end: 16px应用于结束处的填充。
.ion-padding-bottompadding-bottom: 16px应用于底部的填充。
.ion-padding-verticalpadding: 16px 0应用于顶部和底部的填充。
.ion-padding-horizontalpadding: 0 16px应用于左侧和右侧的填充。
.ion-no-paddingpadding: 0应用于所有边的无填充。

元素边距

边距区域使用空区域扩展边框区域,该区域用于将元素与其相邻元素隔开。

默认情况下,将应用的 margin16px,由 --ion-margin 变量设置。有关如何更改这些值的更多信息,请参阅 CSS 变量 部分。

<ion-grid>
<ion-row>
<ion-col class="ion-margin">
<div>margin</div>
</ion-col>
<ion-col class="ion-margin-top">
<div>margin-top</div>
</ion-col>
<ion-col class="ion-margin-start">
<div>margin-start</div>
</ion-col>
<ion-col class="ion-margin-end">
<div>margin-end</div>
</ion-col>
</ion-row>
<ion-row>
<ion-col class="ion-margin-bottom">
<div>margin-bottom</div>
</ion-col>
<ion-col class="ion-margin-vertical">
<div>margin-vertical</div>
</ion-col>
<ion-col class="ion-margin-horizontal">
<div>margin-horizontal</div>
</ion-col>
<ion-col class="ion-no-margin">
<div>no-margin</div>
</ion-col>
</ion-row>
</ion-grid>
样式规则描述
.ion-marginmargin: 16px应用于所有边的边距。
.ion-margin-topmargin-top: 16px应用于顶部的边距。
.ion-margin-startmargin-start: 16px应用于左侧的边距。
.ion-margin-endmargin-end: 16px应用于右侧的边距。
.ion-margin-bottommargin-bottom: 16px应用于底部的边距。
.ion-margin-verticalmargin: 16px 0应用于顶部和底部的边距。
.ion-margin-horizontalmargin: 0 16px应用于左侧和右侧的边距。
.ion-no-marginmargin: 0应用于所有边的无边距。

Flex 属性

Flex 容器属性

<ion-grid>
<ion-row class="ion-justify-content-start">
<ion-col size="3">
<div>1 of 2</div>
</ion-col>
<ion-col size="3">
<div>2 of 2</div>
</ion-col>
</ion-row>

<ion-row class="ion-justify-content-center">
<ion-col size="3">
<div>1 of 2</div>
</ion-col>
<ion-col size="3">
<div>2 of 2</div>
</ion-col>
</ion-row>

<ion-row class="ion-justify-content-end">
<ion-col size="3">
<div>1 of 2</div>
</ion-col>
<ion-col size="3">
<div>2 of 2</div>
</ion-col>
</ion-row>

<ion-row class="ion-justify-content-around">
<ion-col size="3">
<div>1 of 2</div>
</ion-col>
<ion-col size="3">
<div>2 of 2</div>
</ion-col>
</ion-row>

<ion-row class="ion-justify-content-between">
<ion-col size="3">
<div>1 of 2</div>
</ion-col>
<ion-col size="3">
<div>2 of 2</div>
</ion-col>
</ion-row>

<ion-row class="ion-justify-content-evenly">
<ion-col size="3">
<div>1 of 2</div>
</ion-col>
<ion-col size="3">
<div>2 of 2</div>
</ion-col>
</ion-row>
</ion-grid>

<ion-grid>
<ion-row class="ion-align-items-start">
<ion-col>
<div>1 of 4</div>
</ion-col>
<ion-col>
<div>2 of 4</div>
</ion-col>
<ion-col>
<div>3 of 4</div>
</ion-col>
<ion-col>
<div>4 of 4 # # #</div>
</ion-col>
</ion-row>

<ion-row class="ion-align-items-end">
<ion-col>
<div>1 of 4</div>
</ion-col>
<ion-col>
<div>2 of 4</div>
</ion-col>
<ion-col>
<div>3 of 4</div>
</ion-col>
<ion-col>
<div>4 of 4 # # #</div>
</ion-col>
</ion-row>

<ion-row class="ion-align-items-center">
<ion-col>
<div>1 of 4</div>
</ion-col>
<ion-col>
<div>2 of 4</div>
</ion-col>
<ion-col>
<div>3 of 4</div>
</ion-col>
<ion-col>
<div>4 of 4 # # #</div>
</ion-col>
</ion-row>

<ion-row class="ion-align-items-baseline">
<ion-col>
<div>1 of 4</div>
</ion-col>
<ion-col>
<div>2 of 4</div>
</ion-col>
<ion-col>
<div>3 of 4</div>
</ion-col>
<ion-col>
<div>4 of 4 # # #</div>
</ion-col>
</ion-row>

<ion-row class="ion-align-items-stretch">
<ion-col>
<div>1 of 4</div>
</ion-col>
<ion-col>
<div>2 of 4</div>
</ion-col>
<ion-col>
<div>3 of 4</div>
</ion-col>
<ion-col>
<div>4 of 4 # # #</div>
</ion-col>
</ion-row>
</ion-grid>
样式规则描述
.ion-justify-content-startjustify-content: flex-start项目在主轴上向开始处打包。
.ion-justify-content-endjustify-content: flex-end项目在主轴上向结束处打包。
.ion-justify-content-centerjustify-content: center项目沿着主轴居中。
.ion-justify-content-aroundjustify-content: space-around项目均匀分布在主轴上,周围有相等的间距。
.ion-justify-content-betweenjustify-content: space-between项目均匀分布在主轴上。
.ion-justify-content-evenlyjustify-content: space-evenly项目分布使得任何两个项目之间的间距相等。
.ion-align-items-startalign-items: flex-start项目在交叉轴上向开始处打包。
.ion-align-items-endalign-items: flex-end项目在交叉轴上向结束处打包。
.ion-align-items-centeralign-items: center项目沿着交叉轴居中。
.ion-align-items-baselinealign-items: baseline项目对齐,使其基线对齐。
.ion-align-items-stretchalign-items: stretch项目拉伸以填充容器。
.ion-nowrapflex-wrap: nowrap所有项目都将在同一行上。
.ion-wrapflex-wrap: wrap项目将从上到下换行到多行。
.ion-wrap-reverseflex-wrap: wrap-reverse项目将从下到上换行到多行。

Flex 项目属性

<ion-grid>
<ion-row>
<ion-col class="ion-align-self-start">
<div>1 of 4</div>
</ion-col>
<ion-col class="ion-align-self-center">
<div>2 of 4</div>
</ion-col>
<ion-col class="ion-align-self-end">
<div>3 of 4</div>
</ion-col>
<ion-col>
<div>4 of 4 # # #</div>
</ion-col>
</ion-row>
</ion-grid>
样式规则描述
.ion-align-self-startalign-self: flex-start项目在交叉轴上向开始处打包。
.ion-align-self-endalign-self: flex-end项目在交叉轴上向结束处打包。
.ion-align-self-centeralign-self: center项目沿着交叉轴居中。
.ion-align-self-baselinealign-self: baseline项目对齐,使其基线与其他项目基线对齐。
.ion-align-self-stretchalign-self: stretch项目拉伸以填充容器。
.ion-align-self-autoalign-self: auto项目根据父级的 align-items 值进行定位。

边框显示

边框显示 CSS 属性决定是否应显示边框。该属性可以应用于 ion-header 和 ion-footer。

<ion-header class="ion-no-border">
<ion-toolbar>
<ion-title>Header - No Border</ion-title>
</ion-toolbar>
</ion-header>

<ion-footer class="ion-no-border">
<ion-toolbar>
<ion-title>Footer - No Border</ion-title>
</ion-toolbar>
</ion-footer>
描述
.ion-no-border元素将没有边框。

Ionic 断点

Ionic 在媒体查询中使用断点,以便根据屏幕尺寸以不同的方式设置应用程序样式。以下断点名称用于上面列出的实用程序类,其中该类将在满足宽度时应用。

断点名称宽度
xs0
sm576px
md768px
lg992px
xl1200px