自定义博客皮肤VIP专享

*博客头图:

格式为PNG、JPG,宽度*高度大于1920*100像素,不超过2MB,主视觉建议放在右侧,请参照线上博客头图

请上传大于1920*100像素的图片!

博客底图:

图片格式为PNG、JPG,不超过1MB,可上下左右平铺至整个背景

栏目图:

图片格式为PNG、JPG,图片宽度*高度为300*38像素,不超过0.5MB

主标题颜色:

RGB颜色,例如:#AFAFAF

Hover:

RGB颜色,例如:#AFAFAF

副标题颜色:

RGB颜色,例如:#AFAFAF

自定义博客皮肤

-+
  • 博客(33)
  • 收藏
  • 关注

原创 JavaScript继承深入学习记录 从模式开始

JavaScript继承发展1.设计模式1.工厂模式ECMAScript中没法创建类 因此在js中使用一种函数来封装以特定接口创建对象function createPerson(name, age) { let obj = {}; obj.name = name; obj.age = age; obj.sayName = function() { console.log('my name is ' + this.name); } r

2020-08-22 23:35:12 100

原创 js正则学习第一章

chapter11.两种模糊匹配(通过string.match(regExp))横向可匹配不定长的字符串Eg: /ab{2,4}c/ 可匹配"abbc abbbc abbbbc"纵向可匹配多个字符串Eg: /a[123]b/ 可匹配"a1b a2b a3b"2.1字符组[123456abcdEFGH] => [1-6a-dE-H]'-'表示连字符若需要匹配’-’ 则需要转义 eg: [1\-4] or [-14] or [14-] 都表示匹配’1’, ‘-’,

2020-07-19 00:29:38 137

原创 跨域方法实践(jsonp,cors)

同源策略:同源策略限制了一个源(origin)中加载文本或脚本与来自其它源(origin)中资源的交互方式,这是一个用于隔离潜在恶意文件的重要安全机制。如果两个页面拥有 相同 的 协议(protocol),端口(如果指定),和 主机,那么这两个页面就属于同一个源(origin)。1.CORS1.起本地node服务var http = require('http');http.crea...

2020-03-15 13:56:05 175

原创 css使用transform与top延时比较(为什么使用transform)

Css移动位置使用transform与方位top改变的性能区别.box{ width: 100px; height: 100px; border: 1px solid red; position: relative;}//css样式1.使用top修改setTimeout(function () { $('.box').css('top', '200px...

2020-03-14 19:46:23 1299

原创 Chrome中ajax使用file协议加载本地文件非同源问题

Chrome中ajax使用file协议加载本地文件跨域问题1.背景及代码​ 代码目录:​ 1.使用:XMLHttpRequest 创建一个对象 兼容IE// xmlhttp.jsfunction getHTTPObject() { if(typeof XMLHttpRequest === 'undefined') { XMLHttpRequest = functi...

2020-02-24 16:50:21 812

原创 macOS在vscode上配置javaweb完整过程

一.资源下载1.1jdk建议下载jdk11 更稳定(LTS) https://www.oracle.com/java/technologies/javase-jdk11-downloads.html若下载速度过慢 可用华为镜像:https://repo.huaweicloud.com/java/jdk/1.2tomcat 下载9就行http://tomcat.apache.org/...

2020-02-20 12:47:58 2890 1

原创 ["1", "2", "3"].map(parseInt)输出

问题:[“1”, “2”, “3”].map(parseInt);输出什么1.parseInt(string, radix) 接受两个参数 第一个是需要转换的字符串 第二个是转换成多少进制的数 若只有string或radix为0时则默认为10进制2.mapvar new_array = arr.map(function callback(currentValue[, index[, arra...

2020-02-12 13:13:53 194

原创 display:inline-block 产生空隙问题

Display:inline-block 产生空隙问题1.产生原因:元素之间的空白符(空格、回车换行等)都会被浏览器处理,根据white-space的处理方式(默认是normal,合并多余空白),原来HTML代码中的回车换行被转成一个空白符,在字体不为0的情况下,空白符占据一定宽度,所以inline-block的元素之间就出现了空隙。这些元素之间的间距会随着字体的大小而变化,当行内元素font...

2020-01-27 19:32:54 257

原创 js 对象属性排序

let x = { a: 1, b: 5}let y = { a: 3, b: 2}let arr = [x, y]const compare = (proper) => { return (x, y) => { //升序排序 //降序为y-x return x[proper] - y[proper] }}排序前排序后...

2019-12-02 11:42:56 312

原创 npm学习 03npm script 传递参数和添加注释

1.npm script传递参数1. eslint自动修复参数:–fix第一种:可能改了lint:js而没有改lint:js:fix "lint:js": "eslint *.js", "lint:js:fix": "eslint *.js --fix",第二种:代码更加健壮"lint:js": "eslint *.js","lint:js:fix": "npm run lint:...

2019-10-10 10:33:47 563 1

原创 npm学习 02多个npm script串行与并行

package.json{ "name": "npmlearn", "version": "0.1.0", "description": "no", "main": "index.js", "scripts": { "lint:js": "eslint *.js", "lint:css": "stylelint *.less", "lint:json"...

2019-10-09 14:16:57 776

原创 ES6 set

2019-10-08 19:46:14 65

原创 npm学习 01创建并运行npm script

创建并运行npm scriptnpm init快速创建项目使用:npm init在当前目录快速创建package.json 多选项可一路默认回车或使用:npm init -f使用默认配置快速创建修改默认配置:npm config set init.author.email “875952924@qq.com”npm config set init.author.name “linjh”...

2019-10-08 17:48:10 4146

原创 Js高程第五章第三四节 Date RegExp二次学习

1.Date介绍: Date类型使用自 UTC(Coordinated Universal Time,国际协调时间)1970 年 1 月 1 日午夜(零时)开始经过的毫秒数来保存日期在使用这种数据存储格式的条件下,Date 类型保存的日期能够精确到 1970 年 1 月 1 日之前或之后的 285 616 年创建一个Date类型对象let time = new Date()不传递参数的...

2019-09-08 11:39:20 124

原创 Js高程第五章第一二节 Object Array二次学习

Object创建:1.let a = new Object()2.let b = {} 使用这种方式不会调用Object的构造函数调用:1.a.name2.a.[“name”] 若使用了空格或保留字的属性名则需要用方括号调用Array创建:1.let arr = new Array() 括号内可以是数字(长度)也可以是一个数组(数组的初始项)2.let brr = Ar...

2019-09-06 17:19:51 174

原创 Js高程第四章第二节 执行环境及作用域二次学习

执行环境及作用域var color = "blue"; function changeColor(){ var anotherColor = "red"; function swapColors(){ var tempColor = anotherColor; anotherColor = color; color = tempColor; // 这里可以访问 colo...

2019-09-05 21:09:00 95

原创 Js高程第四章第一节 基本类型与引用类型二次学习

JS变量包括基本类型和引用类型定义:1.基本类型:简单的数据段(按值访问)可以操作保存在变量中的实际值2.引用类型:一或多个值构成的对象 JS不允许直接访问内存 不能直接操作对象的内存空间当复制保存着对象的某个变量时,操作的是对象的引用。但在为对象添加属性时,操作的是实际的对象1.动态属性对比: let person = new Object() //引用类型 per...

2019-09-04 17:51:05 88

原创 Js高程十三章事件 未完

事件流1.事件冒泡 自内向外//DOM<!DOCTYPE html> <html> <head> <title>Event Bubbling Example</title> </head> <body> <div id="myDiv">Click Me</div> &...

2019-09-03 21:02:35 98

原创 Js高程十二章 DOM2 DOM3

检测是否支持 document.implementation.hasFeature("Core", "2.0");//true document.implementation.hasFeature("Core", "3.0");//true document.implementation.hasFeature("HTML", "2.0");//true document.implem...

2019-08-31 10:10:37 137

原创 Js高程十一章 DOM扩展

11.1选择符API1.querySelector()方法 接受一个css选择符参考dom结构 : <div id="myDiv"> <em class="uesrname current">e1</em> <em class="sel">e2</em> <em class="sel">e3&l...

2019-08-30 17:26:50 139

原创 JS究极快速排序 in-place 改进快排

普通快排 const quickSort = (arr) => { let left = [], right = [], len = arr.length, pivot = arr[0] if (len < 2) { return arr } for (l...

2019-08-29 21:46:47 293

原创 koa中间件

koa中间件执行顺序顺序为1start2 start3 start3 end2 end1 end

2019-08-28 10:16:54 98

原创 async/await初步使用

koa项目中的async/await使用router.get('/testAsync', async ctx => { global.console.log('start', new Date().getTime()) const a = await new Promise((resolve, reject) => { setTimeout(() => { ...

2019-08-28 09:57:25 165

原创 Js高程第十章DOM-document

取得html各属性 var html = document.documentElement //html body = document.body //body doctype = document.doctype//不同浏览器支持不一致 用处有限 title = document.title //网页title url =...

2019-08-27 22:46:17 73

原创 Js高程第十章DOM-Node类型

节点的childNodes属性 <div id='box'> <p>1-div</p> <div> <p>2-div</p> <h1>2-div</h1> </div> </div> <script> ...

2019-08-26 14:27:47 105

原创 Js高程学习记录第8章BOM

window作用域window.open()timeout interval对话框locationslice splice splitnavgator浏览器插件检测方法historywindow作用域window.open()timeout & interval对话框location & slice splice split复习Navig...

2019-08-22 18:19:32 97

原创 几种垂直居中flex transform

1.使用transform的translateY(x%)属性HTML <div class="inner"></div>CSS html, body { background-color: cadetblue; width: 100%; height: 100%; ...

2019-07-31 20:06:33 153

原创 JavaScript简易轮播图实现及页面数据分离

具体实现步骤:1 创建一个外部div:outer 用来设置轮播图在网页上的位置并设置overflow: hidden将多余图片先隐藏2 创建一个内部div:inner 用来存放图片并设置position: absolute以便之后通过设置left值来改变位置以显示图片3 并且设置transition: all 1s可以使图片切换跟顺畅4 在JS中创建一个对象数组imgCollection保...

2019-06-09 22:51:42 210

原创 JavaScript 函数的call apply bind 方法学习

在JS中每个函数都包含两个非继承而来的方法call()apply()这两个函数作用都是:在特定的作用域中调用函数,等于设置函数体内this对象的值,以扩充函数赖以运行的作用域区别:1.call()接收多个参数 call(this, 参数1, 参数2, …)传递的每个参数需要挨个列举出来2.apply()接收两个参数 apply(this, [参数1, 参数2, …])第一个...

2019-06-02 15:13:28 105

原创 ES6 模板字面量

1.不使用ES6语法时创建多行字符串 const beforeES = { name: 'ljh', age: 20, }; console.log('My name is: ' + beforeES.name + '\n' + 'My age is: ' + beforeES.age + '\n'); //My name i...

2019-06-02 09:33:43 114

原创 ES6 let 和 const的个人学习

let 不能重复声明 var 可以 let immut = 1; var mut = 2; var mut = 4; console.log(mut);//4 let immut = 2; console.log(immut);//immut 以被定义过 不可重复定义

2019-06-02 09:07:18 80

原创 JavaScript 学习笔记 《JavaScript 高级程序设计》3章

3.6 语句1.for-in语法:for(property in expression) statementeg:var showTxt = &amp;amp;quot;&amp;amp;quot;;var person1 = { name:&amp;amp;quot;linjiahao&amp;amp;quot;, age:19, learn:JavaScript };for(var x in person1){ show

2018-12-24 20:36:09 73

原创 JavaScript 数据类型

3.4 数据类型UndefinedNullBooleanNumberStringObject3.4.1 typeof 操作符ECMAScript 为松散类型(即var),用typeof可以检测数据类型。var message = &amp;amp;quot;some string&amp;amp;quot;;alert(typeof message); //&amp;amp;quot;string&amp;amp;quot;

2018-12-11 17:22:35 102

空空如也

空空如也

TA创建的收藏夹 TA关注的收藏夹

TA关注的人

提示
确定要删除当前文章?
取消 删除