静修-个人博客


  • 首页

  • 分类

  • 归档

  • 标签

  • 搜索

07-混合宏

发表于 2018-05-03 | 分类于 前端-07-scss

1、声明混合宏

不带参数混合宏:

在 Sass 中,使用“@mixin”来声明一个混合宏。如:

1
2
3
4
@mixin border-radius{
-webkit-border-radius: 5px;
border-radius: 5px;
}

其中 @mixin 是用来声明混合宏的关键词,有点类似 CSS 中的 @media、@font-face 一样。border-radius 是混合宏的名称。大括号里面是复用的样式代码。

带参数混合宏:

除了声明一个不带参数的混合宏之外,还可以在定义混合宏时带有参数,如:

1
2
3
4
@mixin border-radius($radius:5px){
-webkit-border-radius: $radius;
border-radius: $radius;
}

复杂的混合宏:

上面是一个简单的定义混合宏的方法,当然, Sass 中的混合宏还提供更为复杂的,你可以在大括号里面写上带有逻辑关系,帮助更好的做你想做的事情,如:

1
2
3
4
5
6
7
8
@mixin box-shadow($shadow...) {
@if length($shadow) >= 1 {
@include prefixer(box-shadow, $shadow);
} @else{
$shadow:0 0 4px rgba(0,0,0,.3);
@include prefixer(box-shadow, $shadow);
}
}

这个 box-shadow 的混合宏,带有多个参数,这个时候可以使用“ … ”来替代。简单的解释一下,当 $shadow 的参数数量值大于或等于“ 1 ”时,表示有多个阴影值,反之调用默认的参数值“ 0 0 4px rgba(0,0,0,.3) ”。

2.混合宏-调用混合宏

在 Sass 中通过 @mixin 关键词声明了一个混合宏,那么在实际调用中,其匹配了一个关键词“@include”来调用声明好的混合宏。例如在你的样式中定义了一个圆角的混合宏“border-radius”:

1
2
3
4
@mixin border-radius{
-webkit-border-radius: 3px;
border-radius: 3px;
}

在一个按钮中要调用定义好的混合宏“border-radius”,可以这样使用:

1
2
3
button {
@include border-radius;
}

这个时候编译出来的 CSS:

1
2
3
4
button {
-webkit-border-radius: 3px;
border-radius: 3px;
}

3.混合宏的参数–传一个不带值的参数

Sass 的混合宏有一个强大的功能,可以传参,那么在 Sass 中传参主要有以下几种情形:

A) 传一个不带值的参数

在混合宏中,可以传一个不带任何值的参数,比如:

1
2
3
4
@mixin border-radius($radius){
-webkit-border-radius: $radius;
border-radius: $radius;
}

Sass 的混合宏有一个强大的功能,可以传参,那么在 Sass 中传参主要有以下几种情形:

A) 传一个不带值的参数

在混合宏中,可以传一个不带任何值的参数,比如:

1
2
3
4
@mixin border-radius($radius){
-webkit-border-radius: $radius;
border-radius: $radius;
}

在混合宏“border-radius”中定义了一个不带任何值的参数“$radius”。

在调用的时候可以给这个混合宏传一个参数值:

1
2
3
.box {
@include border-radius(3px);
}

混合宏的参数–传一个带值的参数

在 Sass 的混合宏中,还可以给混合宏的参数传一个默认值,例如:
@mixin border-radius($radius:3px){

1
2
3
-webkit-border-radius: $radius;
border-radius: $radius;
}

在混合宏“border-radius”传了一个参数“$radius”,而且给这个参数赋予了一个默认值“3px”。

在调用类似这样的混合宏时,会多有一个机会,假设你的页面中的圆角很多地方都是“3px”的圆角,那么这个时候只需要调用默认的混合宏“border-radius”:

1
2
3
.btn {
@include border-radius;
}

编译出来的 CSS:

1
2
3
4
.btn {
-webkit-border-radius: 3px;
border-radius: 3px;
}

但有的时候,页面中有些元素的圆角值不一样,那么可以随机给混合宏传值,如:

1
2
3
.box {
@include border-radius(50%);
}

编译出来的 CSS:

1
2
3
4
.box {
-webkit-border-radius: 50%;
border-radius: 50%;
}

混合宏的参数–传多个参数

Sass 混合宏除了能传一个参数之外,还可以传多个参数,如:

1
2
3
4
5
6
7
8
9
@mixin center($width,$height){
width: $width;
height: $height;
position: absolute;
top: 50%;
left: 50%;
margin-top: -($height) / 2;
margin-left: -($width) / 2;
}

在混合宏“center”就传了多个参数。在实际调用和其调用其他混合宏是一样的:

1
2
3
.box-center {
@include center(500px,300px);
}

编译出来 CSS:

1
2
3
4
5
6
7
8
9
.box-center {
width: 500px;
height: 300px;
position: absolute;
top: 50%;
left: 50%;
margin-top: -150px;
margin-left: -250px;
}

有一个特别的参数“…”。当混合宏传的参数过多之时,可以使用参数来替代,如:

1
2
3
4
5
6
7
8
9
10
@mixin box-shadow($shadows...){
@if length($shadows) >= 1 {
-webkit-box-shadow: $shadows;
box-shadow: $shadows;
} @else {
$shadows: 0 0 2px rgba(#000,.25);
-webkit-box-shadow: $shadow;
box-shadow: $shadow;
}
}

编译出来的CSS:

1
2
3
4
.box {
-webkit-box-shadow: 0 0 1px rgba(0, 0, 0, 0.5), 0 0 2px rgba(0, 0, 0, 0.2);
box-shadow: 0 0 1px rgba(0, 0, 0, 0.5), 0 0 2px rgba(0, 0, 0, 0.2);
}

混合宏的参数–混合宏的不足

混合宏在实际编码中给我们带来很多方便之处,特别是对于复用重复代码块。但其最大的不足之处是会生成冗余的代码块。比如在不同的地方调用一个相同的混合宏时。如:

1
2
3
4
5
6
7
8
9
10
11
12
13
@mixin border-radius{
-webkit-border-radius: 3px;
border-radius: 3px;
}

.box {
@include border-radius;
margin-bottom: 5px;
}

.btn {
@include border-radius;
}

示例在“.box”和“.btn”中都调用了定义好的“border-radius”混合宏。先来看编译出来的 CSS:

1
2
3
4
5
6
7
8
9
10
.box {
-webkit-border-radius: 3px;
border-radius: 3px;
margin-bottom: 5px;
}

.btn {
-webkit-border-radius: 3px;
border-radius: 3px;
}

上例明显可以看出,Sass 在调用相同的混合宏时,并不能智能的将相同的样式代码块合并在一起。这也是 Sass 的混合宏最不足之处。

08-AngularJS 从DOM中获取scope

发表于 2018-05-03 | 分类于 前端-06-Angular

参考链接

scope是附加在DOM上,使用了ng-app指令的DOM就是root scope。一般是或body元素

如果要查看某个DOM附加的scope信息,可以按下面的步骤:

  1. 打开chrome的调试面板右键元素,选择检查

  2. 在console面板中输入$0并回车,可以显示当前所选的元素。

  3. 获取附加在他上面的scope信息。执行angular.element($0).scope() 或 仅输入 $scope
    image

08-vscode格式化vue

发表于 2018-05-03 | 分类于 前端-08-vue
  1. 安装 vetur

  2. 在User Setting中增加设置:

    "vetur.format.defaultFormatter.html": "js-beautify-html"
    
  3. 搞定

格式化快捷键:Alt+Shift+F

08-关于flexible

发表于 2018-05-03 | 分类于 前端-08-vue

==最好在html head里加,import方式刷新的时候有bug==

08-扩展 继承

发表于 2018-05-03 | 分类于 前端-07-scss

在 Sass 中也具有继承一说,也是继承类中的样式代码块。在 Sass 中是通过关键词 “@extend”来继承已存在的类样式块,从而实现代码的继承。如下所示:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
//SCSS
.btn {
border: 1px solid #ccc;
padding: 6px 10px;
font-size: 14px;
}

.btn-primary {
background-color: #f36;
color: #fff;
@extend .btn;
}

.btn-second {
background-color: orange;
color: #fff;
@extend .btn;
}

编译出来之后:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
//CSS
.btn, .btn-primary, .btn-second {
border: 1px solid #ccc;
padding: 6px 10px;
font-size: 14px;
}

.btn-primary {
background-color: #f36;
color: #fff;
}

.btn-second {
background-clor: orange;
color: #fff;
}

从示例代码可以看出,在 Sass 中的继承,可以继承类样式块中所有样式代码,而且编译出来的 CSS 会将选择器合并在一起,形成组合选择器:

1
2
3
4
5
.btn, .btn-primary, .btn-second {
border: 1px solid #ccc;
padding: 6px 10px;
font-size: 14px;
}

09-JavaScript获取AngularJS的$scope对象

发表于 2018-05-03 | 分类于 前端-06-Angular

方法1:通过App对象查找

1
2
3
4
5
6
// 通过DOM操作获取ng-app对象
var element = angular.element(document.getElementById("myApp"));
// 通过app对象获取ctrl对象
var controller = element.controller();
// 通过ctrl对象获取$scope
var scope = element.scope();

方法2:通过Controller查找

1
2
3
// 输入参数为ctrl名字
var ctrl= document.querySelector('[ng-controller=ctrlName]');
var scope = angular.element(ctrl).scope();

★使修改后的数据生效

1
scope.$apply();

其他常用方法

1
2
3
4
5
6
// 获取当前元素的$socpe: 
angular.element(domElement).scope()
// 获取当前app的injector:
angular.element(domElement).injector()
// 获取当前元素的controller:
angular.element(domElement).controller()

09-vue-cli配置说明

发表于 2018-05-03 | 分类于 前端-08-vue

webpack

09-占位符

发表于 2018-05-03 | 分类于 前端-07-scss

Sass 中的占位符 %placeholder 功能是一个很强大,很实用的一个功能,这也是我非常喜欢的功能。他可以取代以前 CSS 中的基类造成的代码冗余的情形。因为 %placeholder 声明的代码,如果不被 @extend 调用的话,不会产生任何代码。来看一个演示:

1
2
3
4
5
6
%mt5 {
margin-top: 5px;
}
%pt5{
padding-top: 5px;
}

这段代码没有被 @extend 调用,他并没有产生任何代码块,只是静静的躺在你的某个 SCSS 文件中。只有通过 @extend 调用才会产生代码:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
//SCSS
%mt5 {
margin-top: 5px;
}
%pt5{
padding-top: 5px;
}

.btn {
@extend %mt5;
@extend %pt5;
}

.block {
@extend %mt5;

span {
@extend %pt5;
}
}

编译出来的CSS

1
2
3
4
5
6
7
8
//CSS
.btn, .block {
margin-top: 5px;
}

.btn, .block span {
padding-top: 5px;
}

从编译出来的 CSS 代码可以看出,通过 @extend 调用的占位符,编译出来的代码会将相同的代码合并在一起。这也是我们希望看到的效果,也让你的代码变得更为干净。

10-AngularJS如何判断不同情况设置不同背景色

发表于 2018-05-03 | 分类于 前端-06-Angular

html代码:使用ng-style

1
2
3
4
5
6
7
8
<ul style="float: left;overflow:hidden;" ng-repeat='node in nodedata'>
<li style="list-style-type:none;">
<span ng-style="setColor(node.status)" uib-popover="{{node.nodeIndex|getNodeNameFliter}}"
popover-trigger="mouseenter" type="button" class="btn btn-default dd breath_light"
popover-placement="bottom">{{node.nodeIndex|getNodeNameFliter}}</span>
<i class="icon-chevron-right" style="margin-left:10px;color:green;font-size:20px;"></i>
</li>
</ul>

js代码:

1
2
3
4
5
6
7
8
9
10
11
12
13
$scope.setColor = function (status) {
var p = "";
if (1 == status) {
p = 'red';
} else if (2 == status) {
p = 'yellow';
} else if (3 == status) {
p = 'green';
} else if (4 == status) {
p = 'black';
}
return {"background-color": p};
};

10-ref的说明

发表于 2018-05-03 | 分类于 前端-08-vue

ref

  • 期望类型: string

ref 被用来给元素或子组件注册引用信息。引用信息将会注册在父组件的 $refs 对象上。如果在普通的 DOM 元素上使用,引用指向的就是 DOM 元素; 如果用在子组件上,引用就指向组件实例:

1
2
3
<div id="parent">
<user-profile ref="profile"></user-profile>
</div>
1
2
3
var parent = new Vue({ el: '#parent' })
// 访问子组件
var child = parent.$refs.profile
1…171819…33
静修

静修

322 日志
19 分类
19 标签
© 2019 静修
本站访客数:
由 Hexo 强力驱动
主题 - NexT.Pisces