web前端入门到实战:11 个 CSS 知识搭配 11 个 JS 特性 (实用合集)

这篇文章我会介绍 11 在开发过程中经常遇到的 CSS 相关知识点,以及 11 个有趣亦实用的 JavaScript 特性。

这些都是我在日常开发中总结而来,想必于你也是有或多或少的帮助。

11 个常见的 CSS 知识点

声明,这里也包含了部分 CSS 预处理器知识,愿各位不要纠结于此。

1. position:fixed 降级问题

不知道曾经的你是不是遇到吸顶效果,就是使用 position:fixed 这个属性。其实如果其父元素中有使用 transformfixed 的效果会降级为 absolute

解决方案:

既然会降级为 absolute 效果,我们该怎么解决这个问题呢?我们就改考虑什么情况下 fixedabsolute 的表现效果会是一样的。

即当使用 fixed 的直接父元素的高度和屏幕的高度相同时 fixedabsolute 的表现效果会是一样的。

如果这个直接父级内的元素存在滚动的情况,那就加上 overflow-y:auto

2. 合理使用变量

一般设计稿中的某一类的文字(元素)都是用相同的字体大小、颜色、行高等样式属性,所以这些值我们不必每次都重复写,因为当 UI 更新设计方案,你需要改的地方就很多了。这些重复使用的值我们完全可以存放在变量里面。

Sass 和 Less 稍微有点区别:

// sass$direction: left;// less@direction: left;

当然 CSS 原生也是存在变量的,使用规则如下:

变量定义的语法是:--;// *为变量名称。 变量使用的语法是:var();

  1. 无论是变量的定义和使用只能在声明块 {} 里面
  2. CSS 变量字符限制为:[0-9]、[a-zA-Z]、_、-、中文和韩文等。
:root {    --blue_color: #3388ff;    --main_bgcolor: #fafafa;    --font_size_12: 12px;    --font_size_14: 14px;    --color: 20px;}.div1{    background-color: var(--main_bgcolor);    font-size: var(--font_size_12);}
专门建立的学习Q-q-u-n: 784783012 ,分享学习的方法和需要注意的小细节,不停更新最新的教程和学习技巧
(从零基础开始到前端项目实战教程,学习工具,全栈开发学习路线以及规划)

3. 使用 Mixin 归类重复样式

和重复变量一样,重复的样式也可以归类。我觉得优秀的代码其中有一条肯定是代码的复用性强。

之前我们写 CSS 的时候,也会将一些重复使用的代码放在一个 class 中,这样的确达到了一定的复用性,不过最后的效果可能就是在一个元素里面放了很多 class,如下图:

这样下一个接手得人难免会有点迷糊,而且这样会造成样式越来越难修改。

这个时候,mixin( 可以理解成 class 中的 class )就能发挥它的作用了。

这是一个描述性文字的样式:

.font-description {    .font-des-style(24px,#fff,1.5em);    .line-camp(2);}
// less/* 多行显示 */.line-camp( @clamp:2 ) {    text-overflow: -o-ellipsis-lastline;    overflow: hidden;    text-overflow: ellipsis;    display: -webkit-box;    -webkit-line-clamp: @clamp;    -webkit-box-orient: vertical; }
.font-des-style( @fontSize, @color, @lineHeight, @textAlign:left ) {    font-size: @fontSize;    color: @color;    line-height: @lineHeight;    text-align: @textAlign;}

这只是一个简单的例子,我们可以把可复用的样式放在 mixin 中,这样接手项目的人只需要熟悉你写的 mixin.less 就可以开始迭代需求了

4. 1px 方案

做过移动端需求的前端肯定是避免不了处理 1px 细线问题,这个问题的原因就是 UI 对页面美观度的要求越来越高(不要和我说这是 retina 屏的问题)。

代码如下:

.min-device-pixel-ratio(@scale2, @scale3) {  @media screen and (min-device-pixel-ratio: 2), (-webkit-min-device-pixel-ratio: 2) {    transform: @scale2;  }  @media screen and (min-device-pixel-ratio: 3), (-webkit-min-device-pixel-ratio: 3) {    transform: @scale3;  }}
.border-1px(@color: #DDD, @radius: 2PX, @style: solid) {  &::before {    content: "";    pointer-events: none;    display: block;    position: absolute;    left: 0;    top: 0;    transform-origin: 0 0;    border: 1PX @style @color;    border-radius: @radius;    box-sizing: border-box;    width: 100%;    height: 100%;    @media screen and (min-device-pixel-ratio: 2), (-webkit-min-device-pixel-ratio: 2) {      width: 200%;      height: 200%;      border-radius: @radius * 2;      transform: scale(.5);    }    @media screen and (min-device-pixel-ratio: 3), (-webkit-min-device-pixel-ratio: 3) {      width: 300%;      height: 300%;      border-radius: @radius * 3;      transform: scale(.33);    }  }}
.border-top-1px(@color: #DDD, @style: solid) {  &::before {    content: "";    position: absolute;    left: 0;    top: 0;    width: 100%;    border-top: 1Px @style @color;    transform-origin: 0 0;    .min-device-pixel-ratio(scaleY(.5), scaleY(.33));  }}

5. 内联首屏关键 CSS

性能优化中有一个重要的指标 —— 首次有效绘制(FMP),即指页面的首要内容(primary content)出现在屏幕上的时间。这一指标影响用户看到页面前所需等待的时间,而 内联首屏关键 CSS(即 Critical CSS,可以称之为首屏关键 CSS) 能给用户一个更好的心理预期。

如图:

我们知道内联 CSS 能够使浏览器开始页面渲染的时间提前,即在 HTML 下载完成之后就能渲染了。

既然是内联关键 CSS,也就说明我们只会将少部分的 CSS 代码直接写入 HTML 中。至于内联哪些 CSS 你可以使用 Critical。

6. 文字两端对齐

需求中我们也经常遇到这样的需求,这里直接提供方案。

// html<div>姓名</div><div>手机号码</div><div>账号</div><div>密码</div>
// cssdiv {    margin: 10px 0;     width: 100px;    border: 1px solid red;    text-align: justify;    text-align-last:justify;}div:after{    content: '';    display: inline-block;    width: 100%;}

效果如下:

7. 样式的顺序

CSS 代码:

.red {    color: red;}.blue {    color: blue;}

HTML 代码:

<div class="red blue">这是什么颜色</div><div class="blue red">这是什么颜色</div>

记得之前这是一道比较火的 CSS 考题,当时好像是有不少的人答错(30% 以上)

8. 浏览器会从右到左解析 CSS 选择器

.content_box div p a {    // ...}

浏览器会对上面的例子做如下的步骤处理:

  1. 首先找到页面所有的 <a> 元素
  2. 然后向上找到被 <p> 元素包裹的 <a> 元素
  3. 再向上查找到一直到 .content_box 的元素

从上面的步骤我们可以看出,越靠右的选择器越具有唯一性,浏览器解析 CSS 属性的效率就越高。

所以一定换成使用具体的 class 编写 CSS 代码。

9. 每个单词的首字母大写

其实我第一次看到这个功能的时候就是使用 JS 去实现这个功能:

function capitalizeFirst( str ) {    let result = '';    result = str.toLowerCase().replace(/( |^)[a-z]/g, (L) => L.toUpperCase());    return result} 

直到有一天看到 CSS 也能做这个功能的时候,我才反应过来明明一句 CSS 就能解决的问题,我却使用了更复杂的方案。

CSS 方案如下:

.capitalizeFirst-css {    text-transform: capitalize;}

是不是特别简单。

text-transform 简单介绍

这是 CSS2 中的属性,参数有 capitalize | uppercase | lowercase | none

参数介绍:

  1. none:默认。定义带有小写字母和大写字母的标准的文本。
  2. capitalize:文本中的每个单词以大写字母开头。
  3. uppercase:定义仅有大写字母。
  4. lowercase:定义无大写字母,仅有小写字母。

从这个属性我们可以知道全部大写(小写)的需求这个属性也能轻易实现。

10. 单选高亮

可能你看到“单选高亮”没反应过来,直接来张图片你就马上清楚了:

这个需求用 CSS 更方便处理。主要代码就是一段 CSS 代码:

// 省略部分代码,详细代码看仓库.input:checked + .colors {  border-color: #e63838;  color: #e63838;}
<div class="single-check">    <input class="input" type="radio" name="colors" value="1">    <div class="colors">天空之境</div> </div>

看效果:

两个选择器的区别

~选择器:查找某个元素后面的所有兄弟元素

+选择器:查找某个元素后面紧邻的兄弟元素

11. 多列等高问题

有三种 CSS 的处理方案:

  1. 每列设置一个很大的 padding,再设置一个很大的负的 margin
  2. 使用 display:table;
  3. 使用 flex

第一种有明显的缺陷:

  1. border-bottom 看不到了
  2. 设置的下方的两个圆角也不见了

所以可以使用 display:table; 或者 flex布局 的方式来实现等高。

建议不要一味的抵触 table,有的场景还是可以使用的。

11 个有趣实用的 JS 特性

在日常开发中总是和各种 API 打交道,我们名为前端工程师实为 API 调用工程师。这里分享 11 个实用又有趣的 JS 特性,使用得当可以提高你应用的友好性。

1. 监听屏幕旋转变化接口: orientationchange

定义:

这个 API 可以将你手机是否横屏的情况暴露给需要知道的人知道。

使用:

screenOrientation: function(){    let self = this;    let orientation = screen.orientation || screen.mozOrientation || screen.msOrientation;    window.addEventListener("onorientationchange" in window ? "orientationchange" : "resize", function() {        self.angle = orientation.angle;    });},

通过这个 API 我们在横屏和竖屏的时候可以添加一些动作或者是样式的改变。

如果只是样式的改变也可以通过媒体查询来监听:

/* 竖屏 */@media screen and (orientation: portrait) {    // some css code}/* 横屏 */@media screen and (orientation: landscape) {    // some css code}

2. 电池状态:navigator.getBattery()

定义:

这个 API 可以将你手机电池状态的情况暴露给需要知道的人知道。

这个 api 返回的是一个 promise 对象,会给出一个 BatteryManager 对象,对象中包含了以下信息:

使用:

getBatteryInfo: function(){    let self = this;    if(navigator.getBattery){        navigator.getBattery().then(function(battery) {            // 判断是否在充电            self.batteryInfo = battery.charging ? `在充电 : 剩余 ${battery.level * 100}%` : `没充电 : 剩余 ${battery.level * 100}%`;            // 电池充电状态改变事件            battery.addEventListener('chargingchange', function(){                self.batteryInfo = battery.charging ? `在充电 : 剩余 ${battery.level * 100}%` : `没充电 : 剩余 ${battery.level * 100}%`;            });        });    }else{        self.batteryInfo = '不支持电池状态接口';    }},

3. 让你的手机震动: window.navigator.vibrate(200)

定义:

这个 API 可以让你的手机按你的想法震动。

使用: 震动效果会在很多游戏使用。比如欢乐斗地主中,地主打完王炸后手机都会有震动的效果,以此来表达地主嘚瑟的心情也很是合理。

示例代码如下:

vibrateFun: function(){    let self = this;    if( navigator.vibrate ){        navigator.vibrate([500, 500, 500, 500, 500, 500, 500, 500, 500, 500]);    }else{        self.vibrateInfo = "您的设备不支持震动";    }    <!--    // 清除震动    navigator.vibrate(0);    // 持续震动    setInterval(function() {        navigator.vibrate(200);    }, 500);    -->},

4. 当前语言:navigator.language

定义:

这个 API 可以告诉你当前应该使用什么语言。

如果你需要和我一样做多语言适配,这个 API 或许可以给你提供一个不错的思路。

使用:

不同浏览器返回的值稍微有点差异。你可以通过以下封装好的方法来消除这种差异:

function getThisLang(){    const langList = ['cn','hk','tw','en','fr'];    const langListLen = langList.length;    const thisLang = (navigator.language || navigator.browserLanguage).toLowerCase();    for( let i = 0; i < langListLen; i++ ){        let lang = langList[i];        if(thisLang.includes(lang)){            return lang        }else {          return 'en'        }    }}

不同的语言就对应不同的语言文案就好。

5. 联网状态:navigator.onLine

定义:

这个 API 可以告诉让你知道你的设备的网络状态是否连接着。

使用:

比如我上午登陆了掘金在看一篇文章,可是没看完就到了吃饭的点,这么热爱学习的我肯定是选择吃完午饭回来继续看。

30 分钟过后……

吃晚饭回到公司,打开电脑继续把那篇文章看完,看完了打算点了赞,发现给了这个提示:

这个提示让我有点懵(就是没网络了)。

这个时候我们就可以使用这个 API,这样就可以准确的告诉用户“您的网络无法连接,请检查”。这样用户是不是可以有更好的体验呢?

代码如下:

mounted(){    let self = this;    window.addEventListener('online',  self.updateOnlineStatus, true);    window.addEventListener('offline', self.updateOnlineStatus, true);},methods: {    updateOnlineStatus: function(){        var self = this;        self.onLineInfo = navigator.onLine ? "online" : "offline";    },}

注意:navigator.onLine 只会在机器未连接到局域网或路由器时返回 false,其他情况下均返回 true。也就是说,机器连接上路由器后,即使这个路由器没联通网络, navigator.onLine 仍然返回 true

6. 页面可编辑:contentEditable

定义:

这个 API 可以使页面所有元素成为可编辑状态,使浏览器变成你的编辑器。

使用:

  1. 你可以在地址栏输入 data:text/html,<html contenteditable>, 这样浏览器就变成了编辑器。

使用场景:

需求 —— 页面需要一个文本输入框。

  1. 该文本输入框默认状态下有默认文本提示信息
  2. 文本框输入状态下其高度会随文本内容自动撑开

像这样的需求我们就可以使用 <divcontentEditable='true'></div> 代替 <textarea> 标签。

不过 contentEditable='true' 是不会有 placeholder 的,那 placeholder 怎么办呢?

我一般会使用如下方案,输入内容后改变 class:

<div class='haveInput' contentEditable='true' placeholder='请输入'></div> // css 样式.haveInput:before {    content: attr(placeholder);    display: block;    color: #333;}
专门建立的学习Q-q-u-n: 784783012 ,分享学习的方法和需要注意的小细节,不停更新最新的教程和学习技巧
(从零基础开始到前端项目实战教程,学习工具,全栈开发学习路线以及规划)

好玩的事儿

你可以在浏览器的 consloe 控制台输入 document.body.contentEditable=true,你会发现整个页面都是可编辑的。

可以编辑页面内容,去逗一逗你的朋友,也是一个挺好玩的事儿。(下图我就修改了一些数据)

7. 浏览器活跃窗口监听: window.onblur & window.onfocus

定义:

这两个 api 分别表示窗口失去焦点和窗口处于活跃状态。

浏览其他窗口、浏览器最小化、点击其他程序等, window.onblur 事件就会触发; 回到该窗口,window.onfocus 事件就会触发。

使用:

上面的截图是微信网页版的消息提示。

代码很简单:

mounted(){    let self = this;    window.addEventListener('blur',  self.doFlashTitle, true);    window.addEventListener('focus', function () {        clearInterval(self.timer);        document.title = '微信网页版';    }, true);},methods: {    doFlashTitle: function(){        var self = this;        self.timer = setInterval( () => {            if (!self.flashFlag) {                document.title = "微信网页版";            } else {                document.title = `微信(${self.infoNum})`;            }            self.flashFlag = ! self.flashFlag        }, 500)    },}

8. 全屏 API(Fullscreen API)

定义:

这个 API 可以使你所打开的页面全屏展示,没有其他页面外的内容展示在屏幕上。

使用:

Element.requestFullscreen() 方法用于发出异步请求使元素进入全屏模式。

调用此 API 并不能保证元素一定能够进入全屏模式。如果元素被允许进入全屏幕模式,document 对象会收到一个 fullscreenchange 事件,通知调用者当前元素已经进入全屏模式。如果全屏请求不被许可,则会收到一个 fullscreenerror 事件。

当进入/退出全屏模式时,会触发 fullscreenchange 事件。你可以在监听这个事件,做你想做的事。

fullScreenFun: function(){    let self = this;    var fullscreenEnabled = document.fullscreenEnabled       ||                            document.mozFullScreenEnabled    ||                            document.webkitFullscreenEnabled ||                            document.msFullscreenEnabled;
    if (fullscreenEnabled) {        let de = document.documentElement;        if(self.fullScreenInfo === '打开全屏'){            if( de.requestFullscreen ){                de.requestFullscreen();            }else if( de.mozRequestFullScreen ){                de.mozRequestFullScreen();            }else if( de.webkitRequestFullScreen ){                de.webkitRequestFullScreen();            }            self.fullScreenInfo = '退出全屏'        } else {            if( document.exitFullscreen ){                document.exitFullscreen();            }else if( document.mozCancelFullScreen ){                document.mozCancelFullScreen();            }else if( document.webkitCancelFullScreen ){                document.webkitCancelFullScreen();            }            self.fullScreenInfo = '打开全屏'        }    } else {        self.fullScreenInfo = '浏览器当前不能全屏';    }}

相关:

  1. document.fullscreenElement: 当前处于全屏状态的元素 element
  2. document.fullscreenEnabled: 标记 fullscreen 当前是否可用
  3. document.exitFullscreen(): 退出全屏

9. 利用 a 标签解析 URL

有的时候我们需要从一个 URL 中提取域名,查询关键字,变量参数值等,一般我们会自己去解析 URL 来获取这些内容。可是你或许不知道还有更简单的方法。

即创建一个 a 标签将需要解析的 URL 赋值给 a 的 href 属性,然后我们就能很方便的拿到这些内容。代码如下:

function parseURL(url) {    var a =  document.createElement('a');    a.href = url;    return {        host: a.hostname,        port: a.port,        query: a.search,        params: (function(){            var ret = {},                seg = a.search.replace(/^\?/,'').split('&'),                len = seg.length, i = 0, s;            for (;i<len;i++) {                if (!seg[i]) { continue; }                s = seg[i].split('=');                ret[s[0]] = s[1];            }            return ret;        })(),        hash: a.hash.replace('#','')    };}

10. getBoundingClientRect() 知多少

这个 API 可以告诉你页面中某个元素相对浏览器视窗上下左右的距离。

使用: tab 吸顶可以使用 obj.getBoundingClientRect().top 代替 scrollTop-offsetTop,代码如下:

// html<div class="pride_tab_fixed" ref="pride_tab_fixed">    <div class="pride_tab" :class="titleFixed == true ? 'isFixed' :''">        // some code    </div></div>
// vueexport default {    data(){      return{        titleFixed: false      }    },    activated(){      this.titleFixed = false;      window.addEventListener('scroll', this.handleScroll);    },    methods: {      //滚动监听,头部固定      handleScroll: function () {        let offsetTop = this.$refs.pride_tab_fixed.getBoundingClientRect().top;        this.titleFixed = offsetTop < 0;        // some code      }    }  }

offsetTop 和 getBoundingClientRect() 区别

1. getBoundingClientRect():

用于获得页面中某个元素的左,上,右和下分别相对浏览器视窗的位置。不包含文档卷起来的部分。

该函数返回一个 object 对象,有8个属性:top,right,buttom,left,width,height,x,y

2. offsetTop:

用于获得当前元素到定位父级( element.offsetParent )顶部的距离(偏移值)。

定位父级 offsetParent 的定义是:与当前元素最近的 position != static 的父级元素。

offsetTopoffsetParent 方法相结合可以获得该元素到 body 上边距的距离。代码如下:

getOffset: function(obj,direction){    let offsetL = 0;    let offsetT = 0;    while( obj!== window.document.body && obj !== null ){        offsetL += obj.offsetLeft;        offsetT += obj.offsetTop;        obj = obj.offsetParent;    }    if(direction === 'left'){        return offsetL;    }else {        return offsetT;    }}

11. IntersectionObserver 是什么?

IntersectionObserver 可以用来监听元素是否进入了设备的可视区域之内,而不需要频繁的计算来做这个判断。

所以我们可以用这个特性来处理曝光埋点,而不是用 getBoundingClientRect().top 这种更加损耗性能的方式来处理。

当然你也可以用这个 API 来优化滚动吸顶,代码如下:

IntersectionObserverFun: function() {    let self = this;    let ele = self.$refs.pride_tab_fixed;    if( !!IntersectionObserver ){        let observer = new IntersectionObserver(function(){            let offsetTop = ele.getBoundingClientRect().top;            self.titleFixed = offsetTop < 0;        }, {            threshold: [1]        });        observer.observe(document.getElementsByClassName('title_box')[0]);    } else {        window.addEventListener('scroll', _.throttle(function(){            let offsetTop = ele.getBoundingClientRect().top;            self.titleFixed = offsetTop < 0;        }, 50));    }}, 

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 213,616评论 6 492
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,020评论 3 387
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 159,078评论 0 349
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,040评论 1 285
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,154评论 6 385
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,265评论 1 292
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,298评论 3 412
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,072评论 0 268
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,491评论 1 306
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,795评论 2 328
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,970评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,654评论 4 337
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,272评论 3 318
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,985评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,223评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,815评论 2 365
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,852评论 2 351

推荐阅读更多精彩内容

  • 一:在制作一个Web应用或Web站点的过程中,你是如何考虑他的UI、安全性、高性能、SEO、可维护性以及技术因素的...
    Arno_z阅读 1,146评论 0 1
  •   JavaScript 与 HTML 之间的交互是通过事件实现的。   事件,就是文档或浏览器窗口中发生的一些特...
    霜天晓阅读 3,483评论 1 11
  • 前端开发面试题 面试题目: 根据你的等级和职位的变化,入门级到专家级,广度和深度都会有所增加。 题目类型: 理论知...
    怡宝丶阅读 2,575评论 0 7
  • 很多客户总是有一种想法,认为保险公司收的钱多,赔的钱少,自然就会赚钱。保险公司收到的保费,当做是保险公司的利润,说...
    土妹子阅读 445评论 0 0
  • 备注: 把三个文件放到/usr/local/bin下 把checkout的当前分支推送到远端(文件名:gpr)用法...
    wyh1791阅读 343评论 0 0