主要采用scss 编程式思想实现
以上文件从上到下进行说明
_variables.scss 文件主要写主题色 字体边框等变量
内容如下:
—————————————————————————————————————————————————
// colors $colors: ( // 主题色 'primary': #0066ff, "header-bg":#fff, "header-text":#000, 'pages-bg': #f6f7fb, 'border-color': #f2f2f2, 'page-bottom': #d4d9de, 'status-color': #c3672c, 'info': #4b67af, 'danger': #791a15, 'blue-1': #1f3695, 'blue': #1e78ff, 'gree': #07c160, 'white': #fff, 'white-1': #fcfcfc, 'white-2': #eceef0, 'light': #f9f9f9, 'light-1': #d4d9de, 'grey': #808080, 'grey-1': #666, 'dark-1': #343440, 'dark': #222, 'black': #212121, 'end': #fcb102, //warrary 页面steps 'steps': #333, 'step_title': #fff, 'process_title': #ffc201, //按钮颜色 'btn': #fecd32 ); //font $font:( 'light': SuisseIntl-Light, 'trial': wigrum-light-TRIAL, 'regular': wigrum-regular ); $border-color: map-get($colors, 'grey'); // font size $base-font-size: 1rem; $font-sizes: ( xxs: 0.6154, xs: 0.7692, //10px sm: 0.9231, //12px md: 1, //13px lg: 1.0769, //14px xl: 1.2308, //16px,,,, ); $flex-jc: ( start: flex-start, end: flex-end, center: center, between: space-between, around: space-around, ); $flex-ai: ( start: flex-start, end: flex-end, center: center, stretch: stretch, ); // spacing // 0-5: 0 // .mt-1 => margin top .pb-2 $spacing-types: ( m: margin, p: padding, ); $spacing-directions: ( t: top, r: right, b: bottom, l: left, ); $spacing-base-size: 1; $spacing-sizes: ( 10: 10px, 15: 15px, 20: 25px, 25: 25px, 30: 30px, 35: 35px, );
———————————————————————————————————————————————————————
reset 重置样式 我把几个css 库重置样式统一了一下
主要内容为:
-------------------------------------------------------------------------------------------------------------------------------------------------------------------------
/* ========================================================================== 一、消除不同浏览器对HTML文本呈现的差异 ========================================================================== */ /* ========================================================================== HTML5 display definitions HTML5 新增元素定义 ========================================================================== */ /** * 修正IE 8/9 中未定义的块级元素。 */ article, aside, details, figcaption, figure, footer, header, hgroup, main, nav, section, summary { display: block; } /** * 修正在 IE 8/9 中未定义的 'inline-block' 元素。 */ audio, canvas, video { display: inline-block; } /** * 阻止现在浏览器显示未定义 control 播放控件的 'audio' 声音元素。 * 删除 IOS 5 设备中显示的多余的高度。 */ audio:not([controls]) { display: none; height: 0; } /** * 处理 IE 8/9 中不存在的样式。 */ [hidden] { display: none; } /* ========================================================================== Base 基本设置 ========================================================================== */ /** * 1. 设置默认字体类型为 sans-serif. * 2. 当用户放大或缩小页面时不改变字体大小。 */ html { -ms-text-size-adjust: 100%; /* 2 */ -webkit-text-size-adjust: 100%; /* 2 */ } /** * 删除默认边距。 */ body { margin: 0; } /* ========================================================================== Links 链接 ========================================================================== */ /** * 处理 Chrome 与其它浏览器中关于 'outline' 的不一致性。 */ a:focus { outline: thin dotted; } /** * 为所有浏览器改善当激活或悬停在元素上时元素内容的可读性。 */ a:active, a:hover { outline: 0; } /* ========================================================================== Typography 排版 ========================================================================== */ /** * 处理多变的 'h1' 字体大小及其在 Firefox 4+, Safari 5, 及 Chrome时浏览器中的 * 'section' 与 'article' 元素中的边距。 */ /** * 处理在 IE 8/9, Safari 5, 及 Chrome 没有的样式。 */ abbr[title] { border-bottom: 1px dotted; } /** * 处理 Firefox 4+, Safari 5, 及 Chrome 中默认的 'bolder' 样式为 'bold'. */ b, strong { font-weight: bold; } /** * 处理在 Safari 5 和 Chrome 没有的样式。 */ dfn { font-style: italic; } /** * 处理 Firefox 与其它浏览器的差异。 */ hr { -moz-box-sizing: content-box; box-sizing: content-box; height: 0; } /** * 处理在 IE 8/9 中没有的样式。 */ mark { background: #ff0; color: #000; } /** * 修正确 Safari 5 和 Chrome 中古怪的默认字体。 */ code, kbd, pre, samp { font-family: monospace, serif; } /** * 为所有浏览器改善预格式化文本的可读性。 */ pre { white-space: pre-wrap; } /* * 设置一致的引用格式。 */ q { quotes: "\201C" "\201D" "\2018" "\2019"; } /** * 处理所有浏览器中字体大小的不一致性[译者注:原文直译为:处理所有 * 浏览器中的不一致和多变的字体大小]。 */ small { font-size: 80%; } /** * 阻止所有浏览器中 'sub' 和 'sup' 元素影响 'line-height'. * [译者注:就是不让上标与下标影响行高。] */ sub, sup { font-size: 75%; line-height: 0; position: relative; vertical-align: baseline; } sup { top: -0.5em; } sub { bottom: -0.25em; } /* ========================================================================== Embedded content 嵌入的内容 ========================================================================== */ /** * 删除 IE 8/9 中当内容位于 'a' 中出现的边框。 */ img { border: 0; } /** * 修正 IE 9 中显示古怪的溢出内容。 */ svg:not(:root) { overflow: hidden; } /* ========================================================================== Figures Figure 图像/图表/代码等 ========================================================================== */ /** * 处理在 IE 8/9 和 Safari 5 没有的边距。 */ figure { margin: 0; } /* ========================================================================== Forms ========================================================================== */ /** * [译者注:说是修正颜色嘛,可下面没有关于颜色的呀,这也行?求大神解释!] * 2. 去掉内边距,避免当用户清空表单组时认为出错了。 */ legend { border: 0; /* 1 */ padding: 0; /* 2 */ } /** * 1. 修正所有浏览器中未被继承的字体类型。 * 2. 修正所有浏览器中未被继承的字体大小。 * 3. 处理 Firefox 4+, Safari 5, 及 Chrome 中默认设置不同的外边距。 */ button, input, select, textarea { font-family: inherit; /* 1 */ font-size: 100%; /* 2 */ margin: 0; /* 3 */ } /** * 处理 Firefox 4+ 中的客户端样式表里使用 '!important' 设置的 'line-height'. */ button, input { line-height: normal; } /** * 处理 'button' 和 'select' 的 'text-transform' 继承的不一致性。 * 所有其它表单控件元素不继承 'text-transform' 的值。 * 修正 Chrome, Safari 5+, 及 IE 8+ 中 'button' 的继承样式。 * 修正 Firefox 4+ 和 Opera 中 'select' 的继承样式。 */ button, select { text-transform: none; } /** * 1. 避免 Android 4.0.* 中 WebKit 的一个bug, 防止 'audio' 与 'video' 的播放控件失效。 * 2. 修正 iOS 中不可点击的 'input' 样式。 * 3. 改善图片类型的 'input' 等光标样式的可用性与一致性。 */ button, html input[type="button"], /* 1 */ input[type="reset"], input[type="submit"] { -webkit-appearance: button; /* 2 */ cursor: pointer; /* 3 */ } /** * 重置不可用元素的默认光标样式。 */ button[disabled], html input[disabled] { cursor: default; } /** * 1. 处理 IE 8/9 中设置为 'content-box' 的盒子模型。 * 2. 删除 IE 8/9 中多余的内边距。 */ input[type="checkbox"], input[type="radio"] { box-sizing: border-box; /* 1 */ padding: 0; /* 2 */ } /** * 1. 处理 Safari 5 和 Chrome 中默认设置为 'appearance' 的 'searchfield'. * 2. 处理 Safari 5 和 Chrome 中默认设置为 'box-sizing' 的 'border-box' * (包括不会过时的 '-moz'). */ input[type="search"] { -webkit-appearance: textfield; /* 1 */ -moz-box-sizing: content-box; -webkit-box-sizing: content-box; /* 2 */ box-sizing: content-box; } /** * 删除 Safari 5 和 OS X 上的 Chrome 中的输入框上的内边距和搜索取消按钮。 */ input[type="search"]::-webkit-search-cancel-button, input[type="search"]::-webkit-search-decoration { -webkit-appearance: none; } /** * 删除 Firefox 4+ button 与 input 上的内边距。 */ button::-moz-focus-inner, input::-moz-focus-inner { border: 0; padding: 0; } /** * 1. 删除 IE8/9 中默认的垂直滚动条。 * 2. 改善所有浏览器中的可读性并使文本垂直对齐。 */ textarea { overflow: auto; /* 1 */ vertical-align: top; /* 2 */ } /* ========================================================================== Tables 表格 ========================================================================== */ /** * 删除表格里单元格间的间距。 */ table { border-collapse: collapse; border-spacing: 0; } /* ========================================================================== 2、清除一般标签再浏览器中的默认样式 ========================================================================== */ HTML, body, div, h1, h2, h3, h4, h5, h6, ul, ol, dl, li, dt, dd, p, blockquote, pre, form, fieldset, table, th, td { border:none; margin:0px; padding:0px; } html,body{ /*height: 100%;*/ width: 100%; } address, caption, cite, code, dfn, em, strong, th, var { font-style: normal; font-weight: normal; } a{ text-decoration:none; display: inline-block; outline: none!important; } /*a:link{*/ /* color:#fff;*/ /*}*/ /*a:visited{*/ /* color:#fff;*/ /*}*/ /*a:hover{*/ /* color:#fff;*/ /*}*/ /*a:active{*/ /* color:#fff;*/ /*}*/ input::-ms-clear{ display:none; } input::-ms-reveal{ display:none; } input{ -webkit-appearance: none; margin: 0; outline: none; padding: 0; } img{ border:none; } ul,ol,li{ list-style-type:none; }
-------------------------------------------------------------------------------------------------------------------------------------------------------------------------
style.scss 公共类(其中涉及css一些知识,在这不做介绍,请前往其官网查看)
内容为:
-------------------------------------------------------------------------------------------------------------------------------------------------------------------------
@import "./reset.css"; @import './variables'; @import "./vant"; @each $colorKey, $color in $colors { .text-#{$colorKey} { color: $color!important; } .bg-#{$colorKey} { background-color: $color; } .footer-#{$colorKey} { background-color: $color; } } //font @each $fontKey, $font in $font { .font-#{$fontKey} { font-family: $font; } } // text align @each $var in (left, center, right) { .text-#{$var} { text-align: $var !important; } } @each $sizeKey, $size in $font-sizes { .fs-#{$sizeKey} { font-size: $size * $base-font-size; } } // text overflow .text-ellipsis { display: inline-block; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; } // flex .d-flex { display: flex; } .flex-column { flex-direction: column; } .flex-wrap { flex-wrap: wrap; } @each $key, $value in $flex-jc { .jc-#{$key} { justify-content: $value; } } @each $key, $value in $flex-ai { .ai-#{$key} { align-items: $value; } } .flex-1 { flex: 1; } .flex-grow-1 { flex-grow: 1; } // m-0, mx-0 @each $typeKey, $type in $spacing-types { // .m-1 @each $sizeKey, $size in $spacing-sizes { .#{$typeKey}-#{$sizeKey} { #{$type}: $size * $spacing-base-size; } } // .mx-1 , .my-1 @each $sizeKey, $size in $spacing-sizes { .#{$typeKey}x-#{$sizeKey} { #{$type}-left: $size * $spacing-base-size; #{$type}-right: $size * $spacing-base-size; } .#{$typeKey}y-#{$sizeKey} { #{$type}-top: $size * $spacing-base-size; #{$type}-bottom: $size * $spacing-base-size; } } // .mt-1 @each $directionKey, $direction in $spacing-directions { @each $sizeKey, $size in $spacing-sizes { .#{$typeKey}#{$directionKey}-#{$sizeKey} { #{$type}-#{$direction}: $size * $spacing-base-size; } } } } .link { cursor: pointer; } .text-overflow { text-overflow: ellipsis; overflow: hidden; white-space: nowrap; padding: 5px 10px!important; } @font-face { font-family: 'iconfont'; src: url('../../static/font/iconfont.eot'); src: url('../../static/font/iconfont.eot?#iefix') format('embedded-opentype'), url('../../static/font/iconfont.woff') format('woff'), url('../../static/font/iconfont.ttf') format('truetype'), url('../../static/font/iconfont.svg#iconfont') format('svg'); } .iconfont { font-family: "iconfont"; font-size: 18px; font-style: normal; } html { font-family: 'Source Sans Pro', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, 'Helvetica Neue', Arial, sans-serif; word-spacing: 1px; font-size: 16px; -ms-text-size-adjust: 100%; -webkit-text-size-adjust: 100%; background: map-get($colors, 'white'); color: map-get($colors, 'black'); -moz-osx-font-smoothing: grayscale; -webkit-font-smoothing: antialiased; box-sizing: border-box; } *, *:before, *:after { box-sizing: border-box; margin: 0; } input::-webkit-input-placeholder, textarea::-webkit-input-placeholder { color: #808080; } input:-moz-placeholder, textarea:-moz-placeholder { color: #808080; } input::-moz-placeholder, textarea::-moz-placeholder { color: #808080; } input:-ms-input-placeholder, textarea:-ms-input-placeholder { color: #808080; } .itempadding { padding: 0px 10px; } .clickBtn { height: 30px; line-height: 30px; padding: 0px 15px; font-size: 18px; display: inline-block; border-radius: 2px; color: #fff; border: 1px solid #07c160; background-color: #07c160; } .rejectBtn { background-color: map-get($colors, 'white'); color: #333; border: 1px solid map-get($colors, 'status-color'); } .btn { width: 280px; height: 45px; line-height: 45px; border-radius: 25.5px; border: none; color: #ffffff; box-shadow: 0px 0px 6px #0066ff; background: #0066ff; } .baseComponent { width: 100%; height: 100vh; display: flex; overflow: hidden; background: map-get($colors, 'pages-bg'); flex-direction: column; } .topMenu { height: 60px; background: map-get($colors, 'header-bg'); .back { font-weight: 600!important; } } .bottomMenu { height: 95px; flex-shrink: 0; line-height: 95px; text-align: center; background: map-get($colors, 'header-bg'); } .mainContent { flex: 1; display: flex; flex-direction: column; overflow-y: auto; font-size: 16px!important; } a { text-decoration: none; color:map-get($colors, 'black'); } .salaryDetail{ background: map-get($colors, 'blue'); } .realWage { background: map-get($colors, 'primary'); color: #ffffff; } .borderBox, .overtime_time, .overtime, .overTime_reason, .reimburse, .leave, .list, .leave_reason, .record_tab, .Info, .container_select { background: map-get($colors, 'white'); } .search { background: map-get($colors, 'white'); } .AccountList { border-bottom:1px solid map-get($colors, 'border-color'); } .btnCheck { border-top: 1px solid map-get($colors, 'border-color'); } .overtime_time, .leave_time,.record_tab, .topMenu, .clickTitle, .salaryItem, .consumption_detail, .amount_detail, .searchCustomer{ border-bottom:1px solid map-get($colors, 'border-color'); } .status-active { border: 1px solid map-get($colors, 'status-color') !important; } .addBtn{ text-align: center; margin: 10px 35px; }
-------------------------------------------------------------------------------------------------------------------------------------------------------------------------
vant.scss (框架样式重置)
内容为:
-------------------------------------------------------------------------------------------------------------------------------------------------------------------------
@import "variables.scss"; .m-calendar .m-toolbar .m-month-selector .m-next-btn, .m-calendar .m-toolbar .m-year-selector .m-next-btn { background-image: url("") !important; } .m-calendar .m-toolbar .m-month-selector .m-prev-btn, .m-calendar .m-toolbar .m-year-selector .m-prev-btn { background-image: url("") !important; } // 打卡日历底部border颜色 .m-calendar .m-months-container .m-months-wrapper .m-months .m-row:before { background-color:map-get($colors, 'white')!important; } .van-steps { background-color: map-get($colors, 'white')!important; } // 日历当天打卡背景 .m-calendar .m-months-container .m-months-wrapper .m-months .m-row .m-day .m-today { background: map-get($colors, 'primary')!important; color: #ffffff!important; } //日历头部样式 .m-calendar .m-toolbar { background: map-get($colors, 'white')!important; font-weight: 600!important; } .m-calendar .m-week-header { background: map-get($colors, 'white')!important; } // 报销页面 // .van-cell { // //color: #fff!important; // color: map-get($colors, 'white')!important; //} .van-cell { color: map-get($colors, 'black')!important; //color: #000!important; } .van-field__control { font-size: 16px; } .van-uploader__upload { background-color: map-get($colors, 'white')!important; //background-color: #bd9f6947; border-color: map-get($colors, 'black')!important; } .van-uploader__upload-icon { color: map-get($colors, 'black')!important; } //.van-icon { // color: map-get($colors, 'black')!important; // border-color: map-get($colors, 'black') !important; //} .van-step--finish { color: map-get($colors, 'black')!important; } .van-dropdown-menu__title { color:map-get($colors, 'black')!important; } .van-field__control { color:map-get($colors, 'black')!important; font-size: 16px!important; } .van-radio__label { color:map-get($colors, 'black')!important; } .van-search{ background: map-get($colors, 'white')!important; } .van-search__action{ color: map-get($colors, 'status-color')!important; } .van-search{ background: map-get($colors, 'white')!important; } .van-tabs__line { background:map-get($colors, 'primary')!important; } .van-popup { background-color:map-get($colors, 'white')!important; } .van-step--finish .van-step__circle, .van-step--finish .van-step__line { background-color:map-get($colors, 'primary')!important; } //.van-step--finish { // color: map-get($colors, 'primary')!important; //} .van-dropdown-menu__title { padding: 0px 8px 0px 0px!important; font-size: 16px!important; } .van-field__control { text-indent: 20px!important; } .m-calendar .m-toolbar .m-month-selector .m-next-btn, .m-calendar .m-toolbar .m-month-selector .m-prev-btn, .m-calendar .m-toolbar .m-year-selector .m-next-btn, .m-calendar .m-toolbar .m-year-selector .m-prev-btn { width: 15px!important; height: 15px!important; } .van-checkbox__label { color:map-get($colors, 'black')!important; } .van-button--default { color: #ffffff!important; box-shadow: 0px 0px 6px #0066ff!important; background: #0066ff!important; } .van-collapse-item { border-bottom:1px solid map-get($colors, 'border-color') !important; } .van-button--default { border: none!important; } .van-field__control { //border: 1px solid map-get($colors, 'border-color') !important; border-radius: 3px!important; } .van-image { border:1px solid map-get($colors, 'border-color') !important; }
-------------------------------------------------------------------------------------------------------------------------------------------------------------------------
写html ,只需要将你提前设置好的类名加上就好了
好了,结束。