- 文字阴影:text-shadow
text-shadow: 0px 5px 2px black
参数1:x方向偏移
参数2:y方向偏移
参数3: 阴影模糊程度,值越大越模糊
参数4:阴影颜色
文字颜色浅于背景颜色时,可以用阴影在文字左上方做一个深色浮雕效果:
Document
Document
文字颜色深于背景色时,可以在右下方做一个浅色浮雕效果
Document
box-shadow: h-shadow v-shadow blur spread color inset;
h-shadow 必需。水平阴影的位置。允许负值。
v-shadow 必需。垂直阴影的位置。允许负值。
blur 可选。模糊距离。
spread 可选。阴影的尺寸。
color 可选。阴影的颜色。请参阅 CSS 颜色值。
inset 可选。将外部阴影 (outset) 改为内部阴影。
把第二个let改为var,则可以正常弹框
var tmp;
tmp === undefined //true
var test = {a:1,b:2}
var.c === undefined //true
null表示没有这个对象
document.getElementById('notExistElement') === null //true
使用两个等号的时候,undefined == null //ture
直接使用一个不存在的对象时,会抛出异常
alert(notExistObj)
Uncaught ReferenceError: notExistObj is not defined
所以判断对象是否存在要使用
typeof notExistObj == "undefined"
注意typeof返回的是字符串,比如
typeof 1
"number"
另外,null,undefined和boolean的关系:
null == flase //false
undefined == flase //false
!null == true //true
!undefined == true //true
key1 = "a"
obj = {a:1,b:2}
obj[key1] //输出1
obj.key1 //undefined 不能用这种形式
vw、vh、vmin、vmax 是一种视窗单位,也是相对单位。它相对的不是父节点或者页面的根节点。而是由视窗(Viewport)大小来决定的,单位 1,代表类似于 1%。
视窗(Viewport)是你的浏览器实际显示内容的区域—,换句话说是你的不包括工具栏和按钮的网页浏览器
Document
dfadfas
对于em和rem的区别一句话概括:em相对于父元素,rem相对于根元素。
用于做响应式页面,不过我更倾向于rem,因为em不同元素的参照物不一样(都是该元素父元素),所以在计算的时候不方便,相比之下rem就只有一个参照物(html元素),这样计算起来更清晰。
Document
test1
test2
test3
chrome默认的字体大小是12px,也就是1em默认为12px
上例中test2字体为24px,test3为6px
首先下载字体ttf文件
@font-face {
font-family: 'MyFont';
/*字体名称*/
src: url('myfont.ttf');
/*字体源文件*/
}
body {
font-family: MyFont
}
click to hide
function hideme(e) {
}
Lambda表达式(箭头函数)用于表示一个函数,所以它和函数一样,也拥有参数、返回值、函数体,但它没有函数名,所以Lambda表达式相当于一个匿名函数。
使用方法:
()=>{}
小括号里放参数,大括号里放函数体
箭头函数做回调参数
[5, 8, 9].map(item => item + 1);// -> [6, 9, 10]
当箭头函数有一个参数时,参数两边的括号是可有可无的,但是还是有括号看起来看清楚
const foo = bar => bar + 1;
const bar = (baz) => baz + 1;
箭头函数不带参数时,必须要用括号
const foo = () => "foo";
如果函数体不是只一行,应该用花括号,并显式地返回(如果需要返回值)
const foo = bar => {
const baz = 5;
return bar + baz;
};
foo(1); // -> 6
函数如果只有一行,可以省略return
const foo = bar => bar + 5
alert(foo(5)) //10
如果不止一行,要加花括号,不可以省略return
const foo = bar => {
const baz = 5;
bar + baz;
};
foo(1); // -> undefined
只要加了花括号,就必须要return
const foo = bar => {
bar + 5
}
alert(foo(5)) //undefined
() => {
alert(11)
}
以下是定义加执行:
(() => {
alert(11)
})()
null && (() => {
alert(11)
})()
undefined && (() => {
alert(11)
})()
if (undefined) {
alert("ok")
}
if (null) {
alert("ok")
}