您的位置:首页 > 文旅 > 美景 > 网页设计入门首先要学什么_企业网站管理是什么_深圳全网营销哪里好_it培训

网页设计入门首先要学什么_企业网站管理是什么_深圳全网营销哪里好_it培训

2025/1/8 20:23:11 来源:https://blog.csdn.net/weixin_73223235/article/details/143593375  浏览:    关键词:网页设计入门首先要学什么_企业网站管理是什么_深圳全网营销哪里好_it培训
网页设计入门首先要学什么_企业网站管理是什么_深圳全网营销哪里好_it培训

JavaScript脚本插入

在Web标准技术中,结构标准语言是HTML,表现标准语言是CSS,行为标准语言是JavaScript;

加载Javascript 的两种方式,可以通过在head/body标签中引入script标签,在标签内书写相关的内容;或者存在“xxx.js”文件,将该文件通过src属性加载到<script src="xxx.js"> </script>中,两种方法互斥,选择一种就好;

JavaScript组成  

ECMAScript & BOM & DOM

ECMAScript

描述了 Javascript 的基本语法规则,包括数据类型,变量,运算符;

变量 

Javascript的变量是弱类型变量,定义变量使用var关键字,作用域是当前函数或全局,let声明变量的作用域是当前块或全局,常变量用const关键字;【像for/if内都属于块域】

for(let i=0;i<9;i++)
{str = str + i;
}
console.log(i);
//使用let声明变量时,会产生i未定义undefined的提示,因为let声明的i只能作用在for中,而如果变成var,则作用域是当前函数,就可以使用;

数据类型【6基本类型+1复合类型】

String

字符串内包含双引号,那么字符串整体的外部要用单引号;反之,外部要用双引号;

反引号`作为定界符,确定的是模板字符串,可以用$(变量)来引用变量的值;

Number

有整数、浮点数、内部常量、特殊值;

整数:有十进制、八进制(0打头)、十六进制(0x打头)等;

浮点数:支持科学计数法,3.5E15表示3.5*10的15次方;

内部常量:Math.E自然对数、Math.PI;

特殊数字:NaN-不是数,不恰当的运算的返回值(Undefined的变量参与运算结果是NaN);Infinity-正无穷大;-Infinity-负无穷大; 

Boolean

0、null、未定义/空字符串表示False;其他的是True;

Null

只有null值;不能用作变量或函数名;

注意:typeof(Null)是Object;

Undefined

唯一值undefined,表示“未定义”,当①对象的属性不存在;②声明了变量但从未赋值;

注意:typeof(Undefied)是Undefied; 

Symbol(ES6引入)

Symbol()函数会返回symbol类型的值,具有静态属性/方法;而且其返回的值是唯一的; 

Object--复合(引用)类型

除了以上类型,都是Object类型:字符串对象、数组对象...

判断变量的类型:typeof运算符

例var x = "123";  console.log(typeof x);

运算符

=== 此运算符要求类型数值均相等 ;** 此运算符表示幂运算 ;delete 此运算符会删除对象(可删除)的属性,不是删除对象;

== 运算符:如果运算符的两端都是基本类型,则转换为数字比较;如果对象型,转换为字符串基本数值类型再比较;返回值是true/false;

NaN==NaN   返回 false; 

null==null      返回 true;

undefined==undefined      返回 true;

null==undefined                返回 true;

true=='true'                        转换为数字,左侧是1,右侧是true,返回 false;

= 赋值运算符;返回值是右值;

,逗号运算符;返回值是最右值;

有Undefied参与运算的结果都是NaN;

程序控制结构 

顺序结构、选择结构(if、switch)、循环结构(while、do while、for、for...in、for...of);

其中, for...in 处理迭代的一个对象的可枚举字符串属性 ; for...of 处理可迭代对象的值序列,数组可以迭代每个元素,字符串迭代每个字符;

//for ...  in
const object={a:1,b:2,c:3};
for(const property in object){console.log(`${property}:${object[property]}`);
}
//for ... of
const arry1=['a','b','c'];
for(const element of arry1){console.log(element);
}

console.log()--在控制台输出;

window.alert()--弹出的对话框;

document.write()--数据输出到当前网页中间;

document.getElementByld("id").innerHTML--输出内容放在div内;

JavaScript函数

函数定义

function functionName(arg1,arg2,arg3)    //形参不需要指定类型,变量本身就是弱类型;

{

        [statements]

        [return [expression]]

}

或者

var fun = function (arg1,arg2,arg3)   

{

        [statements]

        [return [expression]]

}                                                        //这个函数是匿名函数

函数参数 
(1) 形参 & 实参

实参会被保留在arguments的类数组对象中,可以在函数内部引用这个数组访问所有传递的实参;

(2) rest 参数

允许形参和实参不一样多,可以传入多个参数,实参赋值给形参后,剩余的参数是rest参数;

(3) 默认参数

在参数列表中已赋值的参数,即默认参数; 

注意:没有参数的 return 语句或者没有 return 语句的函数,函数返回值是undefined;

函数调用

通过函数名()调用;

函数对象的两个方法来调用;

①apply( this参数,函数参数组 );②call( this参数,函数参数1,函数参数2...函数参数n );

区别:传递的参数形式不同;

。。。

严格模式

【开启严格模式】 

脚本:在 js 脚本文件的所有语句前放“use strict” (或‘use strict’);

函数:在函数体前放“use strict” (或‘use strict’);

严格模式通过抛出错误来消除原有静默错误;修复一些导致JavaScript引擎难以执行优化的缺陷;

注意:不开启严格模式,默认是“马虎模式/稀松模式/懒散模式”;

 this的指向与工作模式有关:在非严格模式下,总是指向一个对象;严格模式下,this取任意值;

函数上下文的 this

①函数作为对象的方法调用,this 指向调用该方法的对象;

②普通函数被调用并处于非严格模式,this的值指向全局对象(浏览器中是window);

③使用函数对象的call 方法和apply 方法会改变函数调用时的this;

④使用函数对象的bind 方法来设置函数的 this 值,不用考虑函数是如何被调用的;

①obj.f = function(){...}

②function f1(x,f) { f(x); }     f1(100,function(){...});

③var x=function(){...}

//普通调用函数时

懒散模式/默认模式下 this 指向 window;

严格模式下,this 指向 undefined;   

//构造函数时

在构造函数(用来初始化对象)中,this 指向即将创建的对象;

例:function Parent(name){

        this.name = name;

        }

        //普通调用时 function("st11");

        这个时候如果在默认懒散模式下 this 指向window,将window.name=name;

        //构造函数时调用  new function("st11");

        此时通过new会创建一个对象,那么 this 指向即将被创建的对象X,将X.name=name;

匿名函数、函数嵌套
立即执行函数

 (function (){

// ...

}) ();

箭头函数

(形参)=>{函数体} 

注意:①没有独立this、arguments和super绑定,也不可以被用作方法;

②不能被用作构造函数,使用new调用会引发TypeError;

闭包

函数和作用域绑定在一起,尤其是内部函数作为外部函数的返回值的时候,内部函数和外部函数绑定在一起构成闭包;

function outter() {     //外部函数声明let outNum = 111;     //内部函数也可以访问这个变量function inner() {    //内部函数声明let innerNum = 222;console.log(outNum);//访问外部函数的变量}return inner;  //返回内部函数,与outNum所在作用域形成闭包
}
let demo = outter();
demo();  //在这个函数中可以访问到outNum

这里counter是由counterFunc(10)返回的函数;

作用域

全局作用域

局部作用域-函数作用域,由函数声明{}

块作用域-由{}构成,包括for语句或者if语句{}

声明提升

函数声明和变量声明会提升;函数提升优先级高于变量提升

①var定义的变量(let变量不会)会提升到作用的前边;②函数声明提升大整个作用域的最前面;


写在后边小tips:

同时按下“Fn”和“F12”可以进入开发者工具页面;

版权声明:

本网仅为发布的内容提供存储空间,不对发表、转载的内容提供任何形式的保证。凡本网注明“来源:XXX网络”的作品,均转载自其它媒体,著作权归作者所有,商业转载请联系作者获得授权,非商业转载请注明出处。

我们尊重并感谢每一位作者,均已注明文章来源和作者。如因作品内容、版权或其它问题,请及时与我们联系,联系邮箱:809451989@qq.com,投稿邮箱:809451989@qq.com