_tools.scss 6.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397
  1. /* ==================
  2. 常用工具
  3. ==================== */
  4. .ss-bg-opactity-block {
  5. background-color: rgba(#000, 0.2);
  6. color: #fff;
  7. }
  8. /* ==================
  9. flex布局
  10. ==================== */
  11. .ss-flex {
  12. display: flex;
  13. flex-direction: row;
  14. align-items: center;
  15. }
  16. .ss-flex-2 {
  17. display: flex;
  18. flex-wrap: nowrap;
  19. }
  20. .ss-flex-3 {
  21. display: flex;
  22. flex-wrap: wrap;
  23. }
  24. .ss-flex-1 {
  25. flex: 1;
  26. }
  27. .ss-flex-col {
  28. display: flex;
  29. flex-direction: column;
  30. }
  31. .ss-flex-wrap {
  32. flex-wrap: wrap;
  33. }
  34. .ss-flex-nowrap {
  35. flex-wrap: nowrap;
  36. }
  37. .ss-col-center {
  38. align-items: center;
  39. }
  40. .ss-col-top {
  41. align-items: flex-start;
  42. }
  43. .ss-col-bottom {
  44. align-items: flex-end;
  45. }
  46. .ss-col-stretch {
  47. align-items: stretch;
  48. }
  49. .ss-row-center {
  50. justify-content: center;
  51. }
  52. .ss-row-left {
  53. justify-content: flex-start;
  54. }
  55. .ss-row-right {
  56. justify-content: flex-end;
  57. }
  58. .ss-row-between {
  59. justify-content: space-between;
  60. }
  61. .ss-row-around {
  62. justify-content: space-around;
  63. }
  64. .ss-self-start {
  65. align-self: flex-start;
  66. }
  67. .ss-self-end {
  68. align-self: flex-end;
  69. }
  70. .ss-self-center {
  71. align-self: center;
  72. }
  73. .ss-h-100 {
  74. height: 100%;
  75. }
  76. .ss-w-100 {
  77. width: 100%;
  78. }
  79. // 字体样式
  80. .ss-font-1 {
  81. font-size: 20rpx;
  82. }
  83. .ss-font-2 {
  84. font-size: 24rpx;
  85. }
  86. .ss-font-3 {
  87. font-size: 28rpx;
  88. }
  89. .ss-font-4 {
  90. font-size: 32rpx;
  91. }
  92. .ss-font-5 {
  93. font-size: 36rpx;
  94. }
  95. // 左边距
  96. .ss-margin-left1 {
  97. margin-left: 2.5%;
  98. }
  99. .ss-margin-left2 {
  100. margin-left: 5%;
  101. }
  102. .ss-margin-left3 {
  103. margin-left: 10%;
  104. }
  105. .ss-margin-left4 {
  106. margin-left: 10rpx;
  107. }
  108. .ss-margin-left5 {
  109. margin-left: 15rpx;
  110. }
  111. .ss-margin-left6 {
  112. margin-left: 20rpx;
  113. }
  114. .ss-margin-left7 {
  115. margin-left: 40rpx;
  116. }
  117. // 右边距
  118. .ss-margin-right {
  119. margin-right: 2.5%;
  120. }
  121. .ss-margin-width {
  122. width: 90%;
  123. margin-left: 5%;
  124. margin-top: 20rpx;
  125. box-sizing: border-box;
  126. }
  127. .ss-margin-width2 {
  128. width: 95%;
  129. margin-left: 2.5%;
  130. margin-top: 20rpx;
  131. box-sizing: border-box;
  132. }
  133. // 内边距
  134. .ss-margin-top1 {
  135. padding-top: 5%;
  136. }
  137. .ss-margin-top2 {
  138. padding-top: 10%;
  139. }
  140. .ss-margin-top3 {
  141. padding-top: 15%;
  142. }
  143. .ss-margin-top4 {
  144. padding-top: 20%;
  145. }
  146. .ss-margin-top5 {
  147. padding-top: 10rpx;
  148. }
  149. .ss-margin-top6 {
  150. padding-top: 15rpx;
  151. }
  152. .box-sizing {
  153. box-sizing: border-box;
  154. }
  155. // 首页滚动区域
  156. .scroll-box {
  157. width: 95%;
  158. height: 440rpx;
  159. margin-left: 2.5%;
  160. position: relative;
  161. }
  162. .topAndbootom {
  163. padding-top: 10rpx;
  164. padding-bottom: 10rpx;
  165. }
  166. .public-box {
  167. width: 95%;
  168. margin-left: 2.5%;
  169. box-sizing: border-box;
  170. }
  171. .textIcon {
  172. font-family: iconfont;
  173. color: #1b94d3;
  174. }
  175. .wh {
  176. width: 100%;
  177. height: 100%;
  178. }
  179. .icon-navigation {
  180. font-size: 32rpx;
  181. color: #fff;
  182. font-weight: 700;
  183. }
  184. /* ==================
  185. margin padding: 内外边距
  186. ==================== */
  187. @for $i from 0 through 100 {
  188. // 只要双数和能被5除尽的数
  189. @if $i % 2==0 or $i % 5==0 {
  190. // 得出:u-margin-30或者u-m-30
  191. .ss-margin-#{$i},
  192. .ss-m-#{$i} {
  193. margin: $i + rpx;
  194. }
  195. .ss-m-x-#{$i} {
  196. margin-left: $i + rpx;
  197. margin-right: $i + rpx;
  198. }
  199. .ss-m-y-#{$i} {
  200. margin-top: $i + rpx;
  201. margin-bottom: $i + rpx;
  202. }
  203. // 得出:u-padding-30或者u-p-30
  204. .ss-padding-#{$i},
  205. .ss-p-#{$i} {
  206. padding: $i + rpx;
  207. }
  208. .ss-p-x-#{$i} {
  209. padding-left: $i + rpx;
  210. padding-right: $i + rpx;
  211. }
  212. .ss-p-y-#{$i} {
  213. padding-top: $i + rpx;
  214. padding-bottom: $i + rpx;
  215. }
  216. @each $short, $long in l left, t top, r right, b bottom {
  217. // 缩写版,结果如: u-m-l-30
  218. // 定义外边距
  219. .ss-m-#{$short}-#{$i} {
  220. margin-#{$long}: $i + rpx;
  221. }
  222. // 定义内边距
  223. .ss-p-#{$short}-#{$i} {
  224. padding-#{$long}: $i + rpx;
  225. }
  226. // 完整版,结果如:u-margin-left-30
  227. // 定义外边距
  228. .ss-margin-#{$long}-#{$i} {
  229. margin-#{$long}: $i + rpx;
  230. }
  231. // 定义内边距
  232. .ss-padding-#{$long}-#{$i} {
  233. padding-#{$long}: $i + rpx;
  234. }
  235. }
  236. }
  237. }
  238. /* ==================
  239. radius
  240. ==================== */
  241. @for $i from 0 through 100 {
  242. // 只要双数和能被5除尽的数
  243. @if $i % 2==0 or $i % 5==0 {
  244. .ss-radius-#{$i},
  245. .ss-r-#{$i} {
  246. border-radius: $i + rpx;
  247. }
  248. .ss-r-t-#{$i} {
  249. border-top-left-radius: $i + rpx;
  250. border-top-right-radius: $i + rpx;
  251. }
  252. .ss-r-b-#{$i} {
  253. border-bottom-left-radius: $i + rpx;
  254. border-bottom-right-radius: $i + rpx;
  255. }
  256. @each $short, $long in tl 'top-left', tr 'top-right', bl 'bottom-right', br 'bottom-right' {
  257. // 定义外边距
  258. .ss-r-#{$short}-#{$i} {
  259. border-#{$long}-radius: $i + rpx;
  260. }
  261. // 定义内边距
  262. .ss-radius-#{$long}-#{$i} {
  263. border-#{$long}-radius: $i + rpx;
  264. }
  265. }
  266. }
  267. }
  268. /* ==================
  269. 溢出省略号
  270. @param {Number} 行数
  271. ==================== */
  272. @mixin ellipsis($rowCount: 1) {
  273. // @if $rowCount <=1 {
  274. // overflow: hidden;
  275. // text-overflow: ellipsis;
  276. // white-space: nowrap;
  277. // } @else {
  278. // min-width: 0;
  279. // overflow: hidden;
  280. // text-overflow: ellipsis;
  281. // display: -webkit-box;
  282. // -webkit-line-clamp: $rowCount;
  283. // -webkit-box-orient: vertical;
  284. // }
  285. min-width: 0;
  286. overflow: hidden;
  287. text-overflow: ellipsis;
  288. display: -webkit-box;
  289. -webkit-line-clamp: $rowCount;
  290. -webkit-box-orient: vertical;
  291. }
  292. @for $i from 1 through 6 {
  293. .ss-line-#{$i} {
  294. @include ellipsis($i);
  295. }
  296. }
  297. /* ==================
  298. hover
  299. ==================== */
  300. .ss-hover-class {
  301. background-color: $gray-c;
  302. opacity: 0.6;
  303. }
  304. .ss-hover-btn {
  305. transform: translate(1px, 1px);
  306. }
  307. /* ==================
  308. 底部安全区域
  309. ==================== */
  310. .ss-safe-bottom {
  311. padding-bottom: 0;
  312. padding-bottom: calc(constant(safe-area-inset-bottom) / 5 * 3);
  313. padding-bottom: calc(env(safe-area-inset-bottom) / 5 * 3);
  314. }
  315. /* ==================
  316. 字体大小
  317. ==================== */
  318. @for $i from 20 through 50 {
  319. .ss-font-#{$i} {
  320. font-size: $i + rpx;
  321. }
  322. }
  323. /* ==================
  324. 按钮
  325. ==================== */
  326. .ss-reset-button {
  327. padding: 0;
  328. margin: 0;
  329. font-size: inherit;
  330. background-color: transparent;
  331. color: inherit;
  332. position: relative;
  333. border: 0rpx;
  334. /* #ifndef APP-NVUE */
  335. display: flex;
  336. /* #endif */
  337. align-items: center;
  338. justify-content: center;
  339. box-sizing: border-box;
  340. text-align: center;
  341. text-decoration: none;
  342. white-space: nowrap;
  343. vertical-align: baseline;
  344. transform: translate(0, 0);
  345. }
  346. .ss-reset-button.button-hover {
  347. transform: translate(1px, 1px);
  348. background: none;
  349. }
  350. .ss-reset-button::after {
  351. border: none;
  352. }