javascript基础知识show
1、javascript的数据类型是什么
基本数据类型:String,boolean,Number,Undefined,Null
引用数据类型:Object(Array,Date,RegExp,Function)
判断某变量是否为数组数据类型:
方法1、判断其是否具有“数据性质”,如slice()方法.(但是我们可以自己给变量定义slice方法,故有时会失效)
方法2、obj instanceof Array 在某些IE版本中不正确。
方法3、方法1、2均存在漏洞,在ECMA Script5中定义了新方法Array.isArray(),保证其兼容性,最好的方法如下:
2、已知ID的input输入框,希望获取这个输入框的输入值。(不使用第三方框架)
document.getElementById("ID").value;
3、希望获取页面中所有的checkbox怎做(不使用第三方框架)
function _selectCheckBox(){
var domList = document.getElementsByTagName('input');
var checkBoxList = [];
var len = domList.length;//缓存到局部变量
while(len--){ //使用while的效率会比for循环更高
if(domList[len].type=='checkbox'){
checkBoxList.push(domList[len]);
}
}
alert(checkBoxList);
}
4、设置一个已知ID的html内容为xxx,字体颜色设为黑色(不使用第三方框架)
var dom = document.getElementById("ID");
dom.innerHTML ="xxx";
dom.style.color ="#000";
6、 当一个DOM节点被点击时候,希望执行一个函数,怎做?
-- 直接在DOM里绑定事件:<div onclick="test();"></div>
-- 在js里通过onclick绑定:xxx.onclick=test;
-- 通过事件添加进行绑定:addEventListener(xxx,'click',test);
7、java的事件流模型:
-- “事件冒泡”:事件开始由最具体的元素接受,然后逐级向上传播。
-- “事件捕捉”:事件由最不具体的节点先接收,然后逐级向下,一直到最具体的。
--“DOM事件流”:三个阶段:事件捕捉、目标阶段、事件冒泡
8、what's Ajax and JSON,和优缺点。
Ajax是异步JavaScript的xml,用于在web页面中实现异步数据交互。
优点:
-- 可以使用页面不重载全部内容的情况下加载局部的内容,降低数据传输量
-- 避免用户不断刷新或者跳转页面,提高用户体验。
缺点:
-- 对搜索引擎不友好
-- 要实现Ajax下的前后退功能成本比较大。
-- 可能造成请求书的增加
-- 跨域问题限制
JSON是一种轻量级的数据交换格式,ECMA的一个子集。
优点:
轻量级、易于人的阅读和编写,便于机器(JavaScript)解析,支持复合数据类型(数组、对象、字符串、数字)
8、如下代码输出为?原因。
var a;
alert(typeof a); //undefined
alert(b);//报错
释:Undefined是一个只有一个值的数据类型,这个值就是“undefined”,在使用var声明变量但并未对其赋值进行初始化时,这个变量的值就是undefined。而b由于未来声明将报错。注意未声明的变量和声明了未赋值的是不一样的。
9、如下代码输出为?原因。
var a = null;
alert(typeof a);// object
解释:null是一个只有一个值的数据类型,这个值就是null。表示一个空指针对象,所以用typeof检测会返回“object”.
10、如下代码给出结果
var a = new Object();
a.value=1;
b=a;
b.value =2;
alert(a.value);
//引用数据类型细节
11、一直数组 var stringArray = ["This","is","Baidu","campany"],alert出 “This is Baidu Campany”.
function _combo(){
var foo="get-element-by-id";
var arr = foo.split("-");
for( var i=1;i<arr.length;i++){
arr[i]= arr[i].charAt(0).toUpperCase()+arr[i].substr(1,arr[i].length-1);
}
var msg = arr.join("");
return msg;
}
12、var numberArray = [3,2,1,4,5,6];
-- 对数组进行倒排 输出 [6,5,4,1,2,3];
-- 实现对该数组的降序排列,输出[6,5,4,3,2,1];
var numberArray = [3,2,1,4,5,6];
numberArray.reverse();//[6,5,4,1,2,3];
numberArray.sort(function(a,b){
return b-a;
})
13、输出今天的日期,以YYYY-MM-DD的方式,
var d = new Date();
//获取年,getFullYear()返回四位数
//获取月,月份比较特殊,0是1月,11是12月,
var month = d.getMonth()+1;
//变为两位
month = month<10? '0'+month:month;
//获取日
var day = d.getDate();
day = day<10? '0'+day:day;
alert(year+'-'+month+'-'+day);
14、foo = foo||bar 代码含义
if(!foo) foo=bar;//如果foo存在 值不变,否则把bar赋值给foo;
javascript基础知识show的更多相关文章
- Javascript基础知识总结一
Javascript基础知识总结一 <!DOCTYPE html> <html> <head lang="en"> <meta chars ...
- 学习javascript基础知识系列第二节 - this用法
通过一段代码学习javascript基础知识系列 第二节 - this用法 this是面向对象语言中的一个重要概念,在JAVA,C#等大型语言中,this固定指向运行时的当前对象.但是在javascr ...
- 学习javascript基础知识系列第三节 - ()()用法
总目录:通过一段代码学习javascript基础知识系列 注意: 为了便于执行和演示,建议使用chrome浏览器,按F12,然后按Esc(或手动选择)打开console,在console进行执行和演示 ...
- JavaScript 基础知识 - BOM篇
前言 本篇文章是JavaScript基础知识的BOM篇,如果前面的<JavaScript基础知识-DOM篇>看完了,现在就可以学习BOM了. 注意: 所有的案例都在这里链接: 提取密码密码 ...
- (转)JAVA AJAX教程第二章-JAVASCRIPT基础知识
开篇:JAVASCRIPT是AJAX技术中不可或缺的一部分,所以想学好AJAX以及现在流行的AJAX框架,学好JAVASCRIPT是最重要的.这章我给大家整理了一些JAVASCRIPT的基础知识.常用 ...
- JavaScript基础知识整理
只整理基础知识中关键技术,旨在系统性的学习和备忘. 1.在 JScript 中 null 和 undefined 的主要区别是 null 的操作象数字 0,而 undefined 的操作象特殊值NaN ...
- Jquery源码中的Javascript基础知识(三)
这篇主要说一下在源码中jquery对象是怎样设计实现的,下面是相关代码的简化版本: (function( window, undefined ) { // code 定义变量 jQuery = fun ...
- JavaScript基础知识从浅入深理解(一)
JavaScript的简介 javascript是一门动态弱类型的解释型编程语言,增强页面动态效果,实现页面与用户之间的实时动态的交互. javascript是由三部分组成:ECMAScript.DO ...
- JavaScript基础知识必知!!!
JavaScript一种直译式脚本语言,是一种动态类型.弱类型.基于原型的语言,内置支持类型. JS作用:表单验证,减轻服务端的压力:添加页面动画效果:动态更改页面内容:Ajax网络请求. 下面简单介 ...
- javascript基础知识笔记-自用
笔记内容根据个人基础知识不足不明白之处做的记录.主要看的:https://developer.mozilla.org/zh-CN/docs/Web/JavaScript 1.变量,变量的名字又叫标识符 ...
随机推荐
- inux中shell截取字符串方法总结
shell中截取字符串的方法有很多中, ${expression}一共有9种使用方法. ${parameter:-word} ${parameter:=word} ${parameter:?word} ...
- 使用Canvas绘制背景图
原文 http://www.imququ.com/post/use-canvas-as-background-image.html 最近iCloud Web的Beta版换了UI,整体风格变得和iOS ...
- Hibernate不能自动建表解决办法
最近开始学Hibernate,看的是李刚的那本<轻量级java ee企业应用实战>.头一个hibernate程序,我原原本本的按照书上例子写下来,同时只是改动了些mysql的连接参数,并且 ...
- Python异步通信模块asyncore
https://docs.python.org/2/library/asyncore.html This module provides the basic infrastructure for wr ...
- 学习vulkan的几个有用的网址
<ignore_js_op> 1)一个权威向导网站:https://vulkan-tutorial.com/2)Imagination图形组织官网http://imgtec.eetrend ...
- linux启动时文件系统错误问题
linux开机启动时,文件系统错误(磁盘有坏轨或文件系统出现错误) 原因: 1.系统运行时,突然断电或不正常关机,导致文件系统错误(文件系统错误并不是硬件错误,而是软件数据的问题) ...
- WORD学习之制作座位表
1.点击插入-表格-插入表格,将表格的列数设置为6,行数为10,再点击“确定”按钮
- 1.NoSql简介
NoSQL,指的是非关系型的数据库.随着互联网web2.0网站的兴起,传统的关系数据库在应付web2.0网站,特别是超大规模和高并发的SNS类型的web2.0纯动态网站已经显得力不从心,暴露了很多难以 ...
- 通过代码获取res里生成R.java中的值
引用:http://my.eoe.cn/blue_rain/archive/552.html 有的时候我们生成库文件,需要在里面加入一些UI,并提供出一些xml的资源,那如何在其他项目中使用呢? 我们 ...
- [osx] android studio下修改avd的hosts文件
1. 启动avd 安装/启动avd就不说啦,可以直接在android studio里面操作的 2. 进入adb目录 当然是打开终端来敲命令啦. cd /Users/birdylee/Library/A ...