Skip to content

Latest commit

 

History

History
651 lines (462 loc) · 24.6 KB

The-Front-End.md

File metadata and controls

651 lines (462 loc) · 24.6 KB

[TOC]

Front-End(前端)

HTML(HyperText Markup Language,超文本标记语言)

超文本标记语言是一种用于创建网页的标准标记语言。HTML是一种基础技术,常与CSS、JavaScript一起被众多网站用于设计网页、网页应用程序以及移动应用程序的用户界面。网页浏览器可以读取HTML文件,并将其渲染成可视化网页。HTML描述了一个网站的结构语义随着线索的呈现,使之成为一种标记语言而非编程语言。

confirm() 、prompt() 方法

  • confirm() 显示带有一段消息以及确认按钮和取消按钮的对话框。
  • prompt() 显示可提示用户输入的对话框。
var r = confirm("Press a button!");
if (r==true) {
  alert("You pressed OK!");
} else {
  alert("You pressed Cancel!");
}
var name = prompt("请输入您的名字", "预设值")
if (name!=null && name!="")
{
    document.write("你好," + name + "!今天过得好吗?")
}

Blob

Blob 对象表示一个不可变、原始数据的类文件对象。它的数据可以按文本或二进制的格式进行读取,也可以转换成 ReadableStream 来用于数据操作。

最早是数据库直接用Blob来存储二进制数据对象,这样就不用关注存储数据的格式了。在web领域,Blob对象表示一个只读原始数据的类文件对象,虽然是二进制原始数据但是类似文件的对象,因此可以像操作文件对象一样操作Blob对象。

URL encoding 空格符: + or %20?

URL的空格有时被编码成: %20,有时被编码成加号: +

W3C 标准规定,表单数据(用于GET或POST)当 Content-Typeapplication/x-www-form-urlencoded 时,它指定+空格,URL中查询参数名和参数值中空格要用加号+替代。所以几乎所有使用该规范的浏览器在表单提交后,URL查询参数中空格都会被编成加号+。

遵循 RFC 2396 标准的应用来说,不接受查询字符串中出现加号 +,认为它是非法字符。所以一个安全的举措是URL中统一使用 %20 来编码空格字符。

URL被编码为 RFC 1738 时其中指定 %20

CSS(Cascading Style Sheets,层叠样式表)

CSS 是一种样式表语言,用来描述 HTML 或 XML(包括如 SVG、MathML、XHTML 之类的 XML 分支语言)文档的呈现。CSS 描述了在屏幕、纸质、音频等其它媒体上的元素应该如何被渲染的问题。

CSS去除去掉 <a> 超链接的下划线

  

a:hover {
    color: #4499EE;
    text-decoration: none; /*CSS下划线效果:无下划线*/
    border-bottom: 1px #0099CC dotted /*CSS加一个只有下边的框 边框为虚线*/
}
  • a:link 指正常的未被访问过的链接;
  • a:active 指正在点的链接;
  • a:hover 指鼠标在链接上;
  • a:visited 指已经访问过的链接;
  • text-decoration 是文字修饰效果的意思;
  • none 参数表示超链接文字不显示下划线;
  • underline 参数表示超链接的文字有下划线

pre 标签自动换行

<pre> 元素可定义预格式化的文本。被包围在 pre 元素中的文本通常会保留空格和换行符。而文本也会呈现为等宽字体。

pre {
    white-space: pre-wrap;
    word-wrap: break-word;
}

CSS 属性 z-index

JS(JavaScript)

1996 年 Netscape 创造了 Javascript,微软推出 Jscript,为了统一标准,交由国际标准化组织 ECMA 制定规范(TC39),1997 年 ECMA 发布 262 号标准文件,Ecmascript1.0 发布。

所以:Ecmascript 是一种规范,而 Javascript 是 Ecmascript 的一种超集实现。

ES6 是什么?

  • 2011 年 Ecmascript5.1 发布,之后开始使用年份来代替版本
  • 2015 年 6 月发布了 Ecmascript2015, 简称 ES2015
  • 2016 年 6 月发布了 Ecmascript2016, 简称 ES2016
  • 2017 年 6 月发布了 Ecmascript2016, 简称 ES2017

所以:ES6 是对 5.1 以后版本的泛指。

GoogleChrome/dialog-polyfill

polyfill 仿效一个完整的 ES2015+ 环境,并意图运行于一个应用中而不是一个库/工具。

JS获取子节点、父节点和兄弟节点的若干种方式

一、js获取子节点的方式
  1. 通过获取dom方式直接获取子节点 其中test的父标签id的值,div为标签的名字。getElementsByTagName是一个方法。返回的是一个数组。在访问的时候要按数组的形式访问。
var a = document.getElementById("test").getElementsByTagName("div");
  1. 通过childNodes获取子节点 使用childNodes获取子节点的时候,childNodes返回的是子节点的集合,是一个数组的格式。他会把换行和空格也当成是节点信息。
var b =document.getElementById("test").childNodes;

为了不显示不必须的换行的空格,我们如果要使用childNodes就必须进行必要的过滤。通过正则表达式式取掉不必要的信息。下面是过滤掉

//去掉换行的空格
for(var i=0; i<b.length;i++){
    if(b[i].nodeName == "#text" && !/\s/.test(b.nodeValue)){
        document.getElementById("test").removeChild(b[i]);
    }
}
//打印测试
for(var i=0;i<b.length;i++){
    console.log(i+"---------")
    console.log(b[i]);
}
//补充 document.getElementById("test").childElementCount;  可以直接获取长度 同length
  1. 通过children来获取子节点 利用children来获取子元素是最方便的,他也会返回出一个数组。对其获取子元素的访问只需按数组的访问形式即可。
var getFirstChild = document.getElementById("test").children[0];
  1. 获取第一个子节点 firstChild来获取第一个子元素,但是在有些情况下我们打印的时候会显示undefined,这是什么情况呢??其实firstChild和childNodes是一样的,在浏览器解析的时候会把他当换行和空格一起解析,其实你获取的是第一个子节点,只是这个子节点是一个换行或者是一个空格而已。那么不要忘记和childNodes一样处理呀。
var getFirstChild = document.getElementById("test").firstChild;
  1. firstElementChild获取第一个子节点 使用firstElementChild来获取第一个子元素的时候,这就没有firstChild的那种情况了。会获取到父元素第一个子元素的节点 这样就能直接显示出来文本信息了。他并不会匹配换行和空格信息。
var getFirstChild = document.getElementById("test").firstElementChild;
  1. 获取最后一个子节点 lastChild获取最后一个子节点的方式其实和firstChild是类似的。同样的lastElementChild和firstElementChild也是一样的。不再赘余。
var getLastChildA = document.getElementById("test").lastChild;
 var getLastChildB = document.getElementById("test").lastElementChild;
二、js获取父节点的方式
  1. parentNode获取父节点 获取的是当前元素的直接父元素。parentNode是w3c的标准。
var p  = document.getElementById("test").parentNode;
  1. parentElement获取父节点 parentElement和parentNode一样,只是parentElement是ie的标准。
var p1 = document.getElementById("test").parentElement;
  1. offsetParent获取所有父节点 一看offset我们就知道是偏移量 其实这个是于位置有关的上下级 ,直接能够获取到所有父亲节点, 这个对应的值是body下的所有节点信息。
var p2 = document.getElementById("test").offsetParent;
三、js获取兄弟节点的方式
  1. 通过获取父亲节点再获取子节点来获取兄弟节点
var brother1 = document.getElementById("test").parentNode.children[1];
  1. 获取上一个兄弟节点 在获取前一个兄弟节点的时候可以使用previousSibling和previousElementSibling。他们的区别是previousSibling会匹配字符,包括换行和空格,而不是节点。previousElementSibling则直接匹配节点。
var brother2 = document.getElementById("test").previousElementSibling;
var brother3 = document.getElementById("test").previousSibling;
  1. 获取下一个兄弟节点 同previousSibling和previousElementSibling,nextSibling和nextElementSibling也是类似的。
var brother4 = document.getElementById("test").nextElementSibling;
var brother5 = document.getElementById("test").nextSibling;

is(":checked")勾选框判断

一种是DOM节点属性,读取它的方法就是 attr() 方法 第二种是HTML元素属性,这种属性你看不到,但是确实存在,而且大部分情况和DOM节点属性对应的值一样。 在jQuery中取得这种值的方法是 prop();

$("#checkbox1").attr("checked") // checked
$("#checkbox2").attr("checked") // undefined
$("#checkbox1").is(":checked") // true
$("#checkbox1").prop("checked") //true

从is(":checked")说起 - 哎呦大黄 - 博客园

js判断私有的内网IP

//by https://blog.csdn.net/u013299635/article/details/78357041
function isInnerIpAddress(ipAddress) {
    var isInnerIp = false;//默认给定IP不是内网IP
    var ipNum = getIpNum(ipAddress);
    /**
     * 私有IP:A类  10.0.0.0    -10.255.255.255
     *       B类  172.16.0.0  -172.31.255.255
     *       C类  192.168.0.0 -192.168.255.255
     *       D类   127.0.0.0   -127.255.255.255(环回地址)
     **/
    var aBegin = getIpNum("10.0.0.0");
    var aEnd = getIpNum("10.255.255.255");
    var bBegin = getIpNum("172.16.0.0");
    var bEnd = getIpNum("172.31.255.255");
    var cBegin = getIpNum("192.168.0.0");
    var cEnd = getIpNum("192.168.255.255");
    var dBegin = getIpNum("127.0.0.0");
    var dEnd = getIpNum("127.255.255.255");
    isInnerIp = isInner(ipNum, aBegin, aEnd) || isInner(ipNum, bBegin, bEnd) || isInner(ipNum, cBegin, cEnd) || isInner(ipNum, dBegin, dEnd);

    return isInnerIp;
}

function getIpNum(ipAddress) {/*获取IP数*/
    var ip = ipAddress.split(".");
    if (ip.length !== 4) {
        return 0; //不是ip地扯格式
    }
    var a = parseInt(ip[0]);
    var b = parseInt(ip[1]);
    var c = parseInt(ip[2]);
    var d = parseInt(ip[3]);
    var ipNum = a * 256 * 256 * 256 + b * 256 * 256 + c * 256 + d;
    return ipNum;
}

function isInner(userIp, begin, end){
    return (userIp>=begin) && (userIp<=end);
}

JavaScript中Date对象的内置方法格式化时间

var d = new Date();
console.log(d); // 输出:Mon Nov 04 2013 21:50:33 GMT+0800 (中国标准时间)
console.log(d.toDateString()); // 日期字符串,输出:Mon Nov 04 2013
console.log(d.toGMTString()); // 格林威治时间,输出:Mon, 04 Nov 2013 14:03:05 GMT
console.log(d.toISOString()); // 国际标准组织(ISO)格式,输出:2013-11-04T14:03:05.420Z
console.log(d.toJSON()); // 输出:2013-11-04T14:03:05.420Z
console.log(d.toLocaleDateString()); // 转换为本地日期格式,视环境而定,输出:2013年11月4日
console.log(d.toLocaleString()); // 转换为本地日期和时间格式,视环境而定,输出:2013年11月4日 下午10:03:05
console.log(d.toLocaleTimeString()); // 转换为本地时间格式,视环境而定,输出:下午10:03:05
console.log(d.toString()); // 转换为字符串,输出:Mon Nov 04 2013 22:03:05 GMT+0800 (中国标准时间)
console.log(d.toTimeString()); // 转换为时间字符串,输出:22:03:05 GMT+0800 (中国标准时间)
console.log(d.toUTCString()); // 转换为世界时间,输出:Mon, 04 Nov 2013 14:03:05 GMT

js快速获取li所有列表内容

var ulElement = document.getElementsByClassName("c-issue__articles")[0];
var liElemnts = ulElement.getElementsByClassName('c-issue__article');
var abc = [];
for(let liElement of liElemnts) {
 	let aElements = liElement.getElementsByTagName("a");
 	let href = aElements[0].getAttribute("href");
 	let url = 'https://www.objc.io/' + href.slice(0, href.length - 1);
	abc.push(url);
}

var s = abc.join("\n");
console.log(s);

js生成二维码

获取当前页面url及url参数的方法

window.location 属性

https://www.ihtcboy.com:1024/n/2/?order=pub_date#comment示例:

属性 作用 示例结果
hash 设置或获取 href 属性中在井号“#”后面的分段。 #comment
host 设置或获取 location 或 URL 的 hostname 和 port 号码。(如果是默认80端口的链接,:1024是没有的) www.ihtcboy.com:1024
hostname 设置或获取 location 或 URL 的主机名称部分。 www.ihtcboy.com
href 设置或获取整个 URL 为字符串。 https://www.ihtcboy.com:1024/n/2/?order=pub_date
origin 协议+域名。ie中获取为undefined https://www.ihtcboy.com:1024
pathname 设置或获取对象指定的文件名或路径。 /n/2/
port 设置或获取与 URL 关联的端口号码。 1024
protocol 设置或获取 URL 的协议部分。 https:
search 设置或获取 href 属性中跟在问号后面的部分。 ?order=pub_date

window.location.origin polyfill:

if (!window.location.origin) {
  window.location.origin = window.location.protocol + "//" 
    + window.location.hostname 
    + (window.location.port ? ':' + window.location.port : '');
}

JS正则表达式

向页面注入JS文件

(function() {
  var hm = document.createElement("script");
  hm.src = "http://libs.baidu.com/jquery/2.0.0/jquery.min.js";
  var s = document.getElementsByTagName("title")[0]; 
  s.parentNode.insertBefore(hm, s);
})();

js浏览器返回上一个页面(刷新)

window.history.go(-1);  //返回上一页
window.history.back();  //返回上一页,强行刷新

window.location.reload(); //刷新当前页
window.location.go(-1); //刷新上一页

返回上一页并刷新:

$(function(){
  $("#back").click(function(
  window.location.href = document.referrer;//返回上一页并刷新  
 ))
});

js时间戳转成北京时间格式

function time(time = +new Date()) {
    var date = new Date(time + 8 * 3600 * 1000); // 增加8小时
    return date.toJSON().substr(0, 19).replace('T', ' ');
}
time(); // "2018-08-09 18:25:54"

Date的‘toJSON’方法返回格林威治时间的JSON格式字符串,实际是使用‘toISOString’方法的结果。字符串形如‘2018-08-09T10:20:54.396Z’,转化为北京时间需要额外增加八个时区,我们需要取字符串前19位,然后把‘T’替换为空格,即是我们需要的时间格式。把时间格式中的‘-’修改为‘.’或者其他符号都是可以:

function time(time = +new Date()) {
    var date = new Date(time + 8 * 3600 * 1000);
    return date.toJSON().substr(0, 19).replace('T', ' ').replace(/-/g, '.');
}
time(); // "2018.08.09 18:25:54"

js UTC时间转为北京时间

var utc_datetime = "2019-03-31T08:02:06Z";

function utc2beijing(utc_datetime) {
    // 转为正常的时间格式 年-月-日 时:分:秒
    var T_pos = utc_datetime.indexOf('T');
    var Z_pos = utc_datetime.indexOf('Z');
    var year_month_day = utc_datetime.substr(0,T_pos);
    var hour_minute_second = utc_datetime.substr(T_pos+1,Z_pos-T_pos-1);
    var new_datetime = year_month_day+" "+hour_minute_second; // 2017-03-31 08:02:06

    // 处理成为时间戳
    timestamp = new Date(Date.parse(new_datetime));
    timestamp = timestamp.getTime();
    timestamp = timestamp/1000;

    // 增加8个小时,北京时间比utc时间多八个时区
    var timestamp = timestamp+8*60*60;

    // 时间戳转为时间
    var beijing_datetime = new Date(parseInt(timestamp) * 1000).toLocaleString().replace(/年|月/g, "-").replace(/日/g, " ");
    return beijing_datetime; // 2019-03-31 16:02:06
} 

console.log(utc2beijing(utc_datetime));

JS 中按地址(引用)传递和按值传递问题

JS 中 Json

Web

重排(回流)

Reflow(重排)指的是计算页面布局(Layout)。某个节点Reflow时会重新计算节点的尺寸和位置,而且还有可能触发其后代节点Reflow。在这之后再次触发一次Repaint(重绘)。

当Render Tree中的一部分(或全部)因为元素的尺寸、布局、隐藏等改变而需要重新构建。这就称为回流,每个页面至少需要一次回流,就是页面第一次加载的时候。

在Web页面中,很多状况下会导致回流:

* 调整窗口大小
* 改变字体
* 增加或者移除样式表
* 内容变化
* 激活CSS伪类
* 操作CSS属性
* JavaScript操作DOM
* 计算offsetWidth和offsetHeight
* 设置style属性的值
* CSS3 Animation或Transition

重绘

Repaint(重绘)或者Redraw遍历所有节点,检测节点的可见性、颜色、轮廓等可见的样式属性,然后根据检测的结果更新页面的响应部分。 当 Render Tree 中的一些元素需要更新属性,而这些属性只是影响元素的外观、风格、而不会影响布局的。就是重绘。

将重排和重绘的介绍结合起来,不难发现:重绘(Repaint)不一定会引起回流(Reflow重排),但回流必将引起重绘(Repaint)。

jQuery

维基百科:jQuery是一套跨浏览器的JavaScript库,简化HTML与JavaScript之间的操作。由约翰·雷西格在2006年1月的BarCamp NYC上发布第一个版本。目前由Dave Methvin领导的团队进行开发。

抛弃jQuery,拥抱原生JavaScript

jQuery 代表着传统的以 DOM 为中心的开发模式,但现在复杂页面开发流行的是以 React 为代表的以数据/状态为中心的开发模式

jQuery 获取元素内文本,但不包括其子元素内的文本值的方法

例子:

<li id="listItem">
    This is some text
    <span id="firstSpan">First span text</span>
    <span id="secondSpan">Second span text</span>
</li>

1、jq方法

$("#listitem")
    .clone()    //复制元素
    .children() //获取所有子元素
    .remove()   //删除所有子元素
    .end()  //回到选择的元素
    .text();//获取文本值

2、jq方法

$("#listItem").contents().filter(function(){ 
  return this.nodeType == 3; 
})[0].nodeValue 

3、js方法

document.getElementById("listItem").childNodes[0].nodeValue;

jQuery 查找全部某种id元素

包含字符:

    $("*[id*='DiscountType']").each(function (i, el) {
         //It'll be an array of elements
     });

以字符开关:

    $("*[id^='DiscountType']").each(function (i, el) {
         //It'll be an array of elements
     });

以字符结尾:

    $("*[id$='DiscountType']").each(function (i, el) {
         //It'll be an array of elements
     });

如果要选择id不是给定字符串的元素:

    $("*[id!='DiscountType']").each(function (i, el) {
         //It'll be an array of elements
     });

如果要选择id包含给定单词的元素,则用空格分隔:

    $("*[id~='DiscountType']").each(function (i, el) {
         //It'll be an array of elements
     });

如果要选择id等于给定字符串或以该字符串后跟连字符开头的元素:

    $("*[id|='DiscountType']").each(function (i, el) {
         //It'll be an array of elements
     });

jQuery 获取页面所有的 Input 勾选框的状态,或未勾选的数量

var numberOfChecked = $('input:checkbox:checked').length;
var totalCheckboxes = $('input:checkbox').length;
var numberNotChecked = totalCheckboxes - numberOfChecked;
var numberNotChecked = $('input:checkbox:not(":checked")').length;

TS(TypeScript)

TypeScript 是一种开源的编程语言,该语言项目由微软进行维护和管理。TypeScript 不仅包含 JavaScript 的语法,而且还提供了静态类型检查以及使用看起来像基于类的面向对象编程语法操作 Prototype。

TypeScript 是什么

Bootstrap

Remove default list-style in Bootstrap

To remove the list styles in Bootstrap, use the .list-unstyled class.

.list-unstyled {
  padding-left: 0;
  list-style: none;
}