水平垂直居中、让文本不可复制

让文本不可复制

 -webkit-user-select: none; 
    -ms-user-select: none;
    -moz-user-select: none;
    -khtml-user-select: none;
    user-select: none;
复制代码

添加版权信息思路:

1、答案区域监听copy事件,并阻止这个事件的默认行为。
2、获取选中的内容(window.getSelection())加上版权信息,然后设置到剪切板(clipboarddata.setData())。
复制代码

水平垂直居中

 1、定位 盒子宽高已知, position: absolute; left: 50%; top: 50%; margin-left:-自身一半宽度; margin-top: -自身一半高度;

    2、table-cell布局 父级 display: table-cell; vertical-align: middle;  子级 margin: 0 auto;
    
    3、定位 + transform ; 适用于 子盒子 宽高不定时; (这里是本人常用方法)
        
        position: relative / absolute;
        /*top和left偏移各为50%*/
           top: 50%;
           left: 50%;
        /*translate(-50%,-50%) 偏移自身的宽和高的-50%*/
        transform: translate(-50%, -50%); 注意这里启动了3D硬件加速哦 会增加耗电量的 (至于何是3D加速 请看浏览器进程与线程篇)
    
    4、flex 布局
        父级: 
            /*flex 布局*/
            display: flex;
            /*实现垂直居中*/
            align-items: center;
            /*实现水平居中*/
            justify-content: center;
    
    再加一种水平方向上居中 :margin-left : 50% ; transform: translateX(-50%);

window.onload()和$(document).ready()的区别

window.onload必须等到页面内包括图片的所有元素加载完毕后才能执行。 
$(document).ready()是DOM结构绘制完毕后就执行,不必等到加载完毕。

 window.onload不能同时编写多个,如果有多个window.onload方法,只会执行一个 
$(document).ready()可以同时编写多个,并且都可以得到执行 

如何判断一个object是数组类型

1、Array.isArray([1,2,3])
2、根据对象的class属性(类属性),跨原型链调用toString()方法(比较推荐)
Object.prototype.toString.call([1,2,3]);
3、从原型入手,Array.prototype.isPrototypeOf(obj);

盒子模型你是怎么理解的?

1)盒子模型有两种,W3C和IE盒子模型
(1)w3c的盒模型width=content,不包括margin,padding,border
(2)IE盒模型width=content+padding+border
(3)box-sizing:border-box在已设定的宽度和高度之内去设定padding和border
    box-sizing:content-box在已设定的高度和宽度之外设置padding和border

行内元素,块元素,空元素有哪些?

(1)行内元素:
    a - 锚点,em - 强调,strong - 粗体强调,span - 定义文本内区块,i - 斜体,img - 图片,b - 粗体,label-表格标签,select-项目选择,textarea-多行文本输入框,
    sub - 下标,sup - 上标,q - 短引用,
(2)块元素:
    div - 常用块级,dl-定义列表,dt,dd,ul-非排序列表,li,ol-排序表单,p-段落,h1,h2,h3,h4,h5-标题,table-表格,
    fieldset - form控制组,form - 表单,
(3)空元素:
    br-换行,hr-水平分割线

优雅降级和渐进增强?

优雅降级:一开始就构建功能完整的网站,然后根据低版本浏览器进行兼容。
渐进增强:针对低版本浏览器,保证最基本的功能,然后再根据高版本的浏览器进行交互功能的升级。

你可能感兴趣的:(css)