if for
括号()也算function fn(){
num = 10
}
console.log(num)// 10
// 函数里面的形参是局部变量
//具名函数:
function fn(){
// fn 是函数名
}
//匿名函数
let sum = function(){
// sum 不是函数名,只是一个变量
}
立即执行,无需调用 避免全局变量之间的污染
//写法一:
function(形参){
})(实参)
function fn(形参){
//可写函数名,可不写
})(实参)
//写法二:
(function(形参){
}(实参))
多个立即执行函数必须加结束符,否则报错
(function(){
console.log(111)
})();
(function(){
console.log(222)
})();
当函数没有设置形参,而调用时传递了实参,会在函数内默认用arguments
这个伪数组来存储实参,说他是伪数组是因为没有 pop push
等方法,但是有length
属性
document.querySelector('css选择器')
返回匹配的第一个元素 得到的都是一个DOM对象 document.querySelectorAll('css选择器')
返回所有匹配的元素,放在一个伪数组里
let box = document.querySelector('div')
box.className = 'active'
// 原生js增加类,active 是类名但是会覆盖之前的类,当要修改很多样式时,可以将之前的类也写在=‘’里面
为了解决className容易覆盖以前的类名,我们可以通过classList方式追加和删除类名语法:
元素. classList.add('类名')
元素.classList.remove('类名')
元素. classList.toggle('类名')
intervalID
是一个非零数值,用来标识通过setInterval()
创建的定时器,这个值可以用来作为 clearInterval()
的参数来清除对应的定时器。clearInterval(存储返回值的变量)
开启定时器
//写法一:函数代码写在里面
setInterval(function(){
console.log('你好啊')
},1000)//每间隔1s ,就会调用这个函数一次
//写法二:在外面定义一个函数,在setInterval(函数名,1000),只写函数名,不写(),因为一写就是调用,会立即执行,定时器就失去作用
function show(){
console.log('你好啊')
}
setInterval(show,1000)
let qq = setTimeout(function(
console.log(111)
){
}10000) // 会在10s后调用这个函数,只会执行一次
//清除延时
clearTimeout(qq)
new Date()
//获取当前本地时间
let operateTime = new Date().toLocaleString()
{{item.date | format('yyyy-MM-dd hh-mm-ss')}}
Vue.filter('format',function(value,arg){
function dateFormat(date,format){
if(typeof date === "string"){
var mts = date.match(/(\/Date\((\d+)\)\/)/);
if(mts && mts.length >= 3){
date = parseInt(mts[2]);
}
}
date = new Date(date);
if(!date || date.toUTCString() == "Tnvalid Date") {
return "";
}
var map = {
"M":date.getMonth() + 1, // 月份
“d”:date.getDate(), // 日
“h”:date.getHours(), // 小时
“m”:date.getMinutes(), // 分
“s”:date.getSeconds(), // 秒
“q”:Math.floor((date.getMonth() + 3) / 3), // 季度
“S”:date.getMilliseconds(), // 毫秒
};
format = format.replace(/([yMdhmsqS])+/g,function(all,t){
var v = map[t];
if(v !== undefined) {
if(all.length > 1) {
v = '0' + v;
v = v.substr(v.length - 2);
}
return v;
}else if (t == 'y'){
return (date.getFullYear() + ' ').substr(4 - all.length);
}
return all;
});
return format;
}
})
instanceof
null undefined
,因为这两个类型只有一个值typeof
null 与 object
,object与array
undefined /字符串/数值/Boolean/function
toString()
方法var a = null
定义赋值了,值为nullconsole.log(typeof null) // 'object'
var c = {},
c 保存的是这个对象的地址值,c准确的说是引用类型,{}这个数据,也是对象c
let reg = /前端/
let str = '我要学前端'
检测方法一:reg.test(str)
检测方法二:reg.exec(str)
[a-z] ,[0-9]
// 相当于abcdefg......xyz 规定用户只能输入0-9^ 以什么开头
console.log(/^哈/.test( '二哈')) // false
console.log(/^哈/.test('我开心的哈哈大笑')) //faLse
& 以什么结尾
// 当 ^& 一起用时,表示精确查找 /^哈$/ 被查找的字符串只能是哈
console.log(/^哈$/.test('我开心的哈哈大笑")) // false
console.log(/^哈$/.test('哈哈')) // false
console.log(/^哈$/.test('哈'))/ /true 精确匹配
{n,m}
只能出现n到m次[ ]
[a-z] ,[0-9] [a-zA-Z]
只选其中一个function //constructor(){}
是用来接收 new
实例化时传递的参数// 创建类 class
class Star {
constructor(uname,age){
this.uname = uname;
this.age = age;
}
sing(){
console.log("我唱歌")
}
}
// 利用类创建对象 new
let dh = new Star('刘德华',18)
console.log("age" in ldh)// true
元素.getElementsByTagName()
元素.childNodes
子节点不是子元素,子节点有空白childNodes
会返回包括文本节点在内的所有的节点,标签间的空白(换行)也当做是文本节点,但是在IE8及以下版本不会将空白计算到文本节点中元素.firstChild
子节点不是子元素,子节点有空白文本节点元素.lastChild
子节点不是子元素,子节点有空白文本节点document.body
document.documentElement
document.all
div.style.width
div.currentStyle.width //只有IE 浏览器支持
getComputedStyle(div,null) // 返回的是一个对象,所有样式都在这个对象obj中
getComputedStyle(div,null).width // 不支持IE8 及以下
getComputedStyle()
会返回真实的值,而不是默认值,比如width,后者会返回auto,前者返回真实值currentStyle
和 getComputedStyle()
获取的 样式都只是可读的,不能修改地址:前端面试题库