JS输出、获取元素,变量,事件组成,流程控制,对象,函数

简介: JS输出、获取元素,变量,事件组成,流程控制,对象,函数

1.JS输出、获取元素

输出数据

  • 输入框:prompt()------取过来的值为字符型;
  • 弹出警告框:alert();
  • 将内容写到 HTML 文档中: document.write()方法 ;
  • 写入到浏览器的控制台: console.log() ;
  • 将内容写入html中: innerHTML、innerText;

innerText与innerHTML两个属性的区别:

同:

都是可读写的,可以获取元素里面的内容;

异:

innerText不能识别Html标签 会去除空格和换行;

InnerHTML能识别html标签

即div.innerHTML='<strong>今天是</strong>2019'----其中“今天是”将会变粗

且保留空格和换行;

获取元素

  • 通过 id 获得: document.getElementById()-------id是大小写敏感的字符串
<p id="demo"><p>
 document.getElementById('demo').innerHTML='内容';
  • 通过标签名获得:getElementTagName()方法;
  • 通过类名获得:getElementByClassName()----获得某些元素集合
<div class="fly">倾听</div>
<div class="fly">蜻蜓</div>
var x=document.getElementByClassName('fly');
console.log(x);

两个div中的内容都将输出

  • 返回指定选择器的第一个元素-----querySelector 里面选择器需要加符号 .fly #demo li
<div class="fly">倾听</div>
<div class="fly">蜻蜓</div>
var x=document.getquerySelector('.fly');
console.log(x);

将只得到第一个div中的内容

-返回指定选择器的所有元素集合-----querySelectorAll

<div class="fly">倾听</div>
<div class="fly">蜻蜓</div>
var x=document.getquerySelectorAll('.fly');
console.log(x);

将得到两个div中的内容

2.JS变量

变量名:

变量必须以字母开头

变量也能以 $ 和 _ 符号开头

变量名称对大小写敏感(y 和 Y 是不同的变量)

全局变量:函数外的变量,作用域为全局,即任何地方都可访问;

局部变量:函数内部变量,只可在函数内部被访问;

声明(创建)变量:使用 var关键字

var x;

给变量赋值:

x='demo';

var x='demo';

let关键字:只在 let 命令所在的代码块 {} 内有效----作用域只在循环体内,循环体外的变量不受影响

<script>
var  x = 10;
// 这里输出 x 为 10
{  
    let x = 2;
    // 这里输出 x 为 2
}
// 这里输出 x 为 10
document.getElementById("demo").innerHTML = x;
结果为 10
</script>

const关键字:声明一个或多个常量,声明时必须进行初始化,且初始化后值不可再修改

(定义了一个常量引用一个值,用 const 定义的对象或者数组,是可变的)


变量提升:

var 关键字定义的变量可以在使用后声明,也就是变量可以先使用再声明

let 关键字定义的变量则不可以在使用后声明,也就是变量需要先声明再使用

const声明的常量必须初始化

重置变量

使用 var 关键字声明的变量在任何地方都可以修改;

在相同的作用域或块级作用域中,不能使用 const 关键字来重置 var 和 let关键字声明的变量;

在相同的作用域或块级作用域中,不能使用 const 关键字来重置 const 关键字声明的变量;

const 关键字在不同作用域,或不同块级作用域中是可以重新声明赋值的

3.JS对象

对象:带有属性和方法的特殊数据类型

对象的创建:

(1)var x=new 对象名;等价于x=new 对象名;

(2)以字面量来创建对象:{name1:valu1,name2:valu2}

如:person={age=“50”,color="blue};

(3)构造函数来创建对象:

function 构造函数名(){

this.属性=值;

this.方法=function(){}

}

不需要return 就可以返回结果

对象的调用:

(1)对象里面的属性调用:对象.属性名-----”小点可以理解为的“

(2)另一种调用:对象[‘属性名’],方括号里面的属性必须加引号

(3)对象里面调用方法:对象.方法名()------方法名后面一定要加括号

(4)调用构造函数 必须使用 new

如果 new 了函数内的 this 会指向当前这个 person 并且就算函数内部不 return 也会返回一个对象。

如果不 new 的话函数内的 this 指向的是 window。

对象属性的调用:对象名.属性名

var small={
     name:'小小',
     age:'7',
     goodBye:function(){
           console.log('good');
     }
}

属性或者方法采用: 属性名: 属性值

多个属性之间用逗号隔开

对象方法的调用:对象名.方法名()

small.goodBye();

prototype(原型对象):增加属性或方法

即:构造函数名.prototype.新属性或者新方法



4.JS函数

函数步骤:1.声明 2.调用

执行过程:先调用后声明,将实参传给形参,函数结果应该给调用者

如果实参多于形参,取到形参个数;反之则输出undefined;

函数的调用

  • 函数名()
  • 使用方法被调用


使用构造函数被调用(创建一个新的对象)

箭头函数

(参数1,参数2,参数3)=>{函数声明}

(参数1,参数2,参数3)=>表达式(单一)

相当于 :(参数1,参数2,参数3)=>{return 表达式;}

隐式函数:在函数中调用的参数就是隐式函数;

call()和apply()---------两者第一个参数必须是对象本身

区别:apply()将多个参数结合为一个数组传入;

call()直接作为call的参数传入;


函数返回值return:

(1)return后面的代码不会被执行;

(2)return只能返回一个值------可以用数组或者对象等返回多个值

5.JS事件组成

事件组成:

(1)事件源—事件被触发的对象 如:按钮

var btn=document.getElementById(‘btn’);

(2)事件类型----如何触发什么事件 如:鼠标点击(onclick)还是鼠标移动

(3)事件处理程序—通过一个函数赋值的方式 完成如:

btn.οnclick=function(){ }

6.流程控制:顺序、条件语句、循环语句

顺序:根据先后来流程执行

条件语句:if语句、else语句、if else if语句、switch语句、三元运算符

if语句:

条件成立执行代码,否则什么也不做
if(条件表达式){
  条件成立执行的代码语句
}

else语句:

if(条件表达式){
   执行语句1
}else{
   执行语句2
}
如果表达式为真则执行语句1,假则为语句2

if else if语句

switch语句:


将表达式与value相匹配,如匹配则执行相应语句,如均不匹配则执行最后的语句


三元运算符:

条件表达式 ? 执行语句1:执行语句2

如果条件表达式为真则执行1,如果为假反之

循环语句:for循环,while循环,do while循环,for in循环

for循环:循环代码块一定的次数

while循环:在指定条件为真时循环执行代码块

do while循环:至少执行一次循环,若符合条件则继续执行

for in循环:对象属性将全部输出


相关文章
|
29天前
|
JavaScript 前端开发 程序员
前端原生Js批量修改页面元素属性的2个方法
原生 Js 的 getElementsByClassName 和 querySelectorAll 都能获取批量的页面元素,但是它们之间有些细微的差别,稍不注意,就很容易弄错!
|
1月前
|
JavaScript 前端开发 Java
[JS]同事:这次就算了,下班回去赶紧补补内置函数,再犯肯定被主管骂
本文介绍了JavaScript中常用的函数和方法,包括通用函数、Global对象函数以及数组相关函数。详细列出了每个函数的参数、返回值及使用说明,并提供了示例代码。文章强调了函数的学习应结合源码和实践,适合JavaScript初学者和进阶开发者参考。
42 2
[JS]同事:这次就算了,下班回去赶紧补补内置函数,再犯肯定被主管骂
|
29天前
|
缓存 JavaScript 前端开发
JavaScript 与 DOM 交互的基础及进阶技巧,涵盖 DOM 获取、修改、创建、删除元素的方法,事件处理,性能优化及与其他前端技术的结合,助你构建动态交互的网页应用
本文深入讲解了 JavaScript 与 DOM 交互的基础及进阶技巧,涵盖 DOM 获取、修改、创建、删除元素的方法,事件处理,性能优化及与其他前端技术的结合,助你构建动态交互的网页应用。
41 5
|
1月前
|
监控 JavaScript 算法
深度剖析 Vue.js 响应式原理:从数据劫持到视图更新的全流程详解
本文深入解析Vue.js的响应式机制,从数据劫持到视图更新的全过程,详细讲解了其实现原理和运作流程。
|
1月前
|
前端开发 JavaScript
如何在 JavaScript 中访问和修改 CSS 变量?
【10月更文挑战第28天】通过以上方法,可以在JavaScript中灵活地访问和修改CSS变量,从而实现根据用户交互、页面状态等动态地改变页面样式,为网页添加更多的交互性和动态效果。在实际应用中,可以根据具体的需求和场景选择合适的方法来操作CSS变量。
|
1月前
|
前端开发 JavaScript 数据处理
CSS 变量的作用域和 JavaScript 变量的作用域有什么不同?
【10月更文挑战第28天】CSS变量和JavaScript变量虽然都有各自的作用域概念,但由于它们所属的语言和应用场景不同,其作用域的定义、范围、覆盖规则以及与其他语言特性的交互方式等方面都存在明显的差异。理解这些差异有助于更好地在Web开发中分别运用它们来实现预期的页面效果和功能逻辑。
|
1月前
|
JavaScript 前端开发 开发者
.js的dom元素操作
【10月更文挑战第29天】通过灵活运用这些 DOM 元素操作方法,JavaScript 可以实现丰富的网页交互效果,如动态更新页面内容、响应用户操作、创建和删除页面元素等。在实际开发中,开发者可以根据具体的需求和场景,选择合适的 DOM 元素操作方法来实现所需的功能,为用户提供更加流畅和动态的网页体验。
|
1月前
|
前端开发 JavaScript UED
如何使用 JavaScript 动态修改 CSS 变量的值?
【10月更文挑战第28天】使用JavaScript动态修改CSS变量的值可以为页面带来更丰富的交互效果和动态样式变化,根据不同的应用场景和需求,可以选择合适的方法来实现CSS变量的动态修改,从而提高页面的灵活性和用户体验。
|
1月前
|
前端开发 JavaScript 开发者
除了 Generator 函数,还有哪些 JavaScript 异步编程解决方案?
【10月更文挑战第30天】开发者可以根据具体的项目情况选择合适的方式来处理异步操作,以实现高效、可读和易于维护的代码。
|
2月前
|
存储 JavaScript 前端开发
js事件队列
【10月更文挑战第15天】
51 6