1.JavaScript语言特点

  1.弱类型,数据类型由数据的值决定

  2.解释性脚本语言--解释器是JS引擎 是浏览器的一部分

  3.运行在客户端浏览器上

  4.有事件驱动机制(按下鼠标,移动窗口等)

  5.与操作系统无关,跨平台语言

2.盒子模型

  标准盒子模型:左右margin+左右padding+左右border+width

  IE盒子模型:左右margin+width(包括padding和border)

3.CSS Sprite 是一种网页图片应用处理技术,将一个页面需要用到的图片整合成一张或少张图片 以此来减少网页的HTTP请求,提高性能,这是它最大的优点

  使用方法 设置其为background-img:url(),设置其定位:background-position:x,y

  它的优点:减少网页的http请求 提升性能

       减少了图片的字节,多张图片合成一张图片的字节小于多张图片的总和

       减少了命名困扰,只需对一张集合的图片命名,提高制作效率

       更换风格方便,只需在一张或少张图片上修改图片的颜色或样式

  它的缺点:合成麻烦

4.link和@import的区别

  1.link属于HTML标签,而import是css提供的

  2.页面加载时,link会被同事加载,而@import引用的css样式会后加载

  3.link无兼容问题,而import只在IE5以上才能被识别到

  4.link的权重高于import

5.CSS中可以继承的属性有:font-size、color

5.在原型链上对数组去重

var a = 10;
function a(){
}
console.log(typeof a);

Array.prototype.unique1 = function (arr) {
var n = []; //一个新的临时数组
for (var i = 0; i < this.length; i++) //遍历当前数组
{
//如果当前数组的第i已经保存进了临时数组,那么跳过,
//否则把当前项push到临时数组里面
if (n.indexOf(this[i]) == -1) n.push(this[i]);
}
return n;
}
var arr = [2,5,8,7,4,9,5,6,1,2,5];
console.log(arr.unique1());

6.关于原型

function A(x){
this.x= x;
}
A.prototype.x = 1;
function B(x){
this.x= x;
}

B.prototype = new A();
var a = new A(2);
var b = new B();
console.log(a.x,b.x);//2 undefined

B的原型由A的构造函数创建 在A构造函数中 x这个属性声明且复制为undefined,当执行b.x 时先在对象中寻找x属性值 若不存在则去原型中寻找

7.关于原型

var A = {n:4399};
var B= function(){this.n = 9999};
var C = function(){var n = 8888};
// 将B和C的原型都设置为A对象
B.prototype =A;
C.prototype = A;
var b = new B();
var c = new C();
// 对象A的属性n++ n=4400
A.n++;
// 这是输出b.n 会先去自己的对象中查找属性 找到n=9999
console.log(b.n);
console.log(c.n);//对象没有属性 去原型中查找 n=4400

8.用for in 遍历对象属性时不仅遍历对象本身的属性和方法,同时会遍历原型链上的属性和方法

Object.prototype.bar = 1;

var foo = {moo : 2};

for(var i in foo){

  console.log(i);

}

9.函数执行后变量无返回值

var x = 1, y = z = 0;

function add(n) {

n = n+1;

}

y = add(x);//执行add 但函数并未return返回值,此时变量会被赋值为undefined

function add(n) {

n = n + 3;

}

z = add(x);//与y同理

10.下列代码的输出结果

alert(typeof(null));  //object

alert(typeof(undefined)); //undefined

alert(typeof(NaN));  //number

alert(NaN==undefined); //false NaN与任何数据类型比较结果都为false

alert(NaN==NaN); //false

var str="123abc";

alert(typeof(str++)); //number 会对str进行隐士转换为Number 但是转换失败 所以类型为number 值为NaN

alert(str);//NaN

JavaScript-- 基础知识面试题的更多相关文章

  1. Javascript基础知识面试题

    []==![] 解题思路: step1,   []==!Boolean([]);step2,   []==!true;step3,   []==false;step4,   [].valueOf()= ...

  2. java基础知识面试题(41-95)

    41.日期和时间:- 如何取得年月日.小时分钟秒?- 如何取得从1970年1月1日0时0分0秒到现在的毫秒数?- 如何取得某月的最后一天?- 如何格式化日期?答:问题1:创建java.util.Cal ...

  3. java基础知识面试题(1-40)

    1.面向对象的特征有哪些方面?答:面向对象的特征主要有以下几个方面:- 抽象:抽象是将一类对象的共同特征总结出来构造类的过程,包括数据抽象和行为抽象两方面.抽象只关注对象有哪些属性和行为,并不关注这些 ...

  4. Java 基础知识面试题(2020 最新版)

    Java面试总结汇总,整理了包括Java基础知识,集合容器,并发编程,JVM,常用开源框架Spring,MyBatis,数据库,中间件等,包含了作为一个Java工程师在面试中需要用到或者可能用到的绝大 ...

  5. 50道JavaScript基础面试题(附答案)

    https://segmentfault.com/a/1190000015288700 1 介绍JavaScript的基本数据类型 Number.String .Boolean .Null.Undef ...

  6. (转)50道JavaScript基础面试题(附答案)

    https://segmentfault.com/a/1190000015288700 1 介绍JavaScript的基本数据类型 Number.String .Boolean .Null.Undef ...

  7. Java基础知识面试题及答案-整理

    1.String类可以被继承吗?  不能.String类在声明中使用final关键字修饰符.使用final关键字修饰的类无法被继承. Java语言的开发者为什么要将String类定义为final类呢? ...

  8. Java 基础知识面试题

    equals与==有什么区别? (1)==是判断两个变量或实例是不是指向同一个内存空间 (2)equals是判断两个变量或实例所指向的内存空间的值是不是相同 Object有哪些公用方法? (1)equ ...

  9. Java基础知识面试题(最详细版)

    刚刚经历过秋招,看了大量的面经,顺便将常见的Java常考知识点总结了一下,并根据被问到的频率大致做了一个标注.一颗星表示知识点需要了解,被问到的频率不高,面试时起码能说个差不多.两颗星表示被问到的频率 ...

  10. Java基础知识面试题详解(2019年)

    文章目录 1. 面向对象和面向过程的区别 2. Java 语言有哪些特点? 3. 关于 JVM JDK 和 JRE 最详细通俗的解答 JVM JDK 和 JRE 4. Oracle JDK 和 Ope ...

随机推荐

  1. flutter的生命周期

    大致可以看成三个阶段 初始化(插入渲染树) 状态改变(在渲染树中存在) 销毁(从渲染树种移除) initState 当插入渲染树的时候调用,这个函数在生命周期中只调用一次.这里可以做一些初始化工作,比 ...

  2. HBase里配置SNAPPY压缩以后regionserver启动不了的问题

    配置了HBase的SNAPPY压缩以后,出现regionserver启动不了的问题.分析应该是属性配置错了! 官网上的是:<name>hbase.regionserver.codecs&l ...

  3. 自定义string类

    #include <iostream> #include <cstring> using namespace std; class String; class Data{ // ...

  4. Nginx在线服务状态下平滑升级或新增模块

    nginx在使用过程中,有时需要在不影响当前业务的情况下,进行升级或新增模块.nginx的升级有两种方法:1.半自动化升级:2.手动升级 不过都需要先查看安装的nginx版本和配置信息,然后前往官网下 ...

  5. iOS的多线程技术

    iOS的三种多线程技术 1.NSThread 每个NSThread对象对应一个线程,量级较轻(真正的多线程) 2.以下两点是苹果专门开发的“并发”技术,使得程序员可以不再去关心线程的具体使用问题 ØN ...

  6. OpenGL学习笔记 之一 (基本的图形绘制)

    参考网址:http://www.cnblogs.com/FredCong/archive/2012/10/13/2722893.html #include <glut.h> #includ ...

  7. go基础系列 第二章 go指针

    一. 指针 先来看一段代码 var pa *int pa = &a *pa = fmt.Println(a) 这里定义了一个int类型的变量a, 有定义了一个指针类型的变量pa, 让pa指向了 ...

  8. kotlin基本数据类型

    通过idea创建kotlin项目: 创建kotlin文件 package com.czhappy.chapter01 var aBoolean:Boolean = true var anInt:Int ...

  9. sql语句中,取得schema中的所有表信息及表的定义结构

    postgressql下'検索スキーマの中で.全てテーブルselect tablename from pg_tables where schemaname='test' mysql下'検索スキーマの中 ...

  10. js 读取文本文件,日志内容

    <!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <title> ...