JS基础-运算符-函数
1.运算符
1.赋值运算符和扩展运算符
1.赋值运算符 =
2.扩展运算符
+=,-=,*=,/=,%=,^=....
ex:
a=a+b;--> a+=b;
a=a+1;--> a++,a+=1,++a
实现两个数字的换位:
a^=b;
b^=a;
a^=b;
2.条件运算符
条件运算符又称三目运算符。
单目(一元)运算符,只需要一个操作数或表达式。
ex:++,--,!
双目(二元)运算符,需要两个操作或表达式
ex:+,-,*,/,%,>,<,>=,<=,==,===,!=,!==,&,|,^,&&,||
三目(三元)运算符,需要三个表达式或操作数。
语法:
条件表达式?表达式1:表达式2;
先判断条件表达式的值,如果条件为true,则执行表达式1,如果条件为false,则执行表达式2。
ex:
从弹出框中输入成绩,如果成绩大于60,则输出及格,否则输出不及格。
练习:
从弹出框中输入成绩:
如果成绩等于100,则输出"奖励1000元",
如果成绩>=90,则输出"奖励100元",
如果成绩>=70,则输出"奖励10元素",
否则,输出"请大家吃饭"。
2.函数
1.什么是函数
函数,function,也称为方法
函数-功能。
函数是一段预定义好,并可以被反复执行的代码块。
预定义:提前定义好,并非马上执行。
反复执行:允许被多次调用。
代码块:可以包含多条可执行的语句
使用过的函数:
parseInt();
parseFloat();
Number();
alert();
document.write();
2.定义和使用函数
1.普通函数的声明和使用
1.声明
function 函数名(){
//函数体-若干可执行的代码
}
2.调用函数
在任意javascript合法位置处通过
函数名(); 对函数进行调用。
3.要同时调用多个函数方式如下:
function test(){
calculate(); //调用函数1
print();//调用函数2
}
练习:
1.定义一个函数名称calaulate(计算)
在函数体内,定义两个变量,num1, num2并赋值为数字,计算两个数字之和,并打印在控制台。
2.在网页中添加一个按钮,单击按钮时调用函数。
2.带参函数的声明和使用
1.声明
function 函数名(参数列表){
//函数体-js语句
}
参数列表:可以声明1个或多个参数,多个参数间用逗号分隔。
声明函数时,声明的参数称为“形参”。
2.调用
函数名(参数值列表);
注意:尽量按照声明函数的格式进行调用
调用时,传递的参数值称为“实参”。
练习:
定义带参函数,函数体内计算两个参数的乘积,并打印输出。单击按钮时调用函数。
3.带返回值函数的声明和使用
1.声明
function 函数名(){
//函数体
return 值;
}
2.调用
允许使用一个变量接收函数的返回值
var result=函数名();
练习:
定义一个可以接收三个参数的函数,函数体内返回三个数字的和。并将结果打印在控制台。
3.函数的作用域
1.变量作用域
作用域表示的是变量或函数的可访问范围。
js中的作用域分为两种:
1.函数作用域:只在函数范围内有效
函数作用域又称为局部变量,只在声明的函数中有效
2.全局作用域:js代码的任何位置都有效
全局作用域又称全局变量,一经声明,任何位置都能使用。
1.不在function中声明的变量,为全局变量
2.声明变量不使用var ,无论任何位置声明,都是全局变量(不推荐)
2.注意
1.全局变量和局部变量冲突时,优先使用局部变量。
2.声明提前
js程序正式执行之前,function声明的函数,会将所有var声明的变量,都预读到所在作用域的顶部,但赋值还是保留在原位置。
函数同样也有声明提前的功能。
3.按值传递
1.什么是按值传递
原始数据类型,在做参数传递时,都是按照“值传递”的方式来传参。
值传递:真正传递参数时,实际上传递的是值的副本(复制出来一个值),而不是原始值。
*以后不要把原始数据类型拿到函数中去修改值。
练习:
1.创建变量score,赋值为90;
2.再创建函数changeScore(num),在函数体内将num+5再输出。
3.调用changeScore函数,并将score以实参传入函数,再输出score的值。
3.函数作用域
分为两种:
1.局部函数
在某个function中声明的函数
2.全局函数
在最外层<script>定义的函数就是全局函数,全局函数一经定义,任何位置都能调用。
4.ECMAScript提供一组全局函数
1.parseInt();
2.parseFloat();
3.Number();
4.isNaN();
5.encodeURI();
URL:Uniform Resource Locator统一资源定位器,俗称:路径
URI:Uniform Resource Identifier(标识符)
作用:对统一资源标识符进行编码,并返回编码后的字符串。
所谓的编码,就是将地址中多字节的文字编码成单字节文字。
6.decodeURI();
作用:对已编码的URI进行解码,并返回解码后的字符串。
7.encodeURIComponent();
在encodeURI的基础上,允许对特殊字符进行编码。
8.decodeURIComponent();
允许对特殊字符解码。
9.eval();
作用:执行以字符串表示的js代码
练习:
定义一个函数,在函数体内接收弹出框输入的一段js代码(document.write("<h1>js全局函数</h1>")),并用eval函数来执行该段js代码。
5.递归调用
递归:在一个函数的内部再一次调用自己。
问题:想要求5的阶乘
5! 5*4*3*2*1 -->5*4!
4! 4*3*2*1 -->4*3!
3! 3*2*1 -->3*2!
2! 2*1 -->2*1!
1! 1*1
求n的阶乘,用一个函数表示?
function f(n){
/*if(n==1){
return 1;
}else{
return n*f(n-1)
}*/
return n==1?1:n*f(n-1)
}
效率:
在本次调用还未结束时,就开始下次的调用,本次调用就会被挂起,直到所有的调用都完成之后,才会依次返回,调用次数越多,效率越低。
练习:
以下数列(斐波拉契数列)
1,1,2,3,5,8,13,21,34,55......
通过f(n)计算数列中第n个数字的值。
已知:
该数列中第一个数和第二个数都是1。
从第三个数开始,每个数字都是前两个数字的和。
f(1)=1
f(2)=1
f(3)=f(2)+f(1)
f(4)=f(3)+f(2)
...
f(n)=f(n-1)+f(n-2)
JS基础-运算符-函数的更多相关文章
- js基础——运算符
爱创课堂前端培训--js基础 运算符一.运算符 运算符(Operators,也翻译为操作符),是发起运算的最简单形式.分类:(运算符的分类仁者见智,本课程进行一下分类.)数学运算符(Arithmeti ...
- JS基础:函数
函数声明和函数表达式 在 JS 中定义函数的方式有两种:一种是函数声明,一种是函数表达式. 例如: //函数声明 function fun() { ... } //函数表达式 var f = func ...
- JS笔记 运算符 函数
1.运算符 1.位运算符 将数字转换为二进制后进行运算 只做整数运算,如果是小数的话,则去掉小数位再运算 2.位运算 1.按位 与:& 语法:a&b; 2.按位 或| 语法:a|b 任 ...
- js基础-运算符
100 * "20" 字符串转数字 5 * "ss" NAN "ss" 转数字返回NAN 任何数字与NAN +-*/ 都返回NAN 5/N ...
- Js基础之函数
定义函数:我们使用function标签来定义函数 使用函数:JavaScript函数定义完毕是不能自动执行的,需要我们调用或者事件触发,比如点击事件,鼠标事件,键盘事件等. 下面我们以点击事件为例,调 ...
- js基础:函数表达式和函数声明
函数表达式和函数声明的区别.实际上,解析器在向执行环境中加载数据是,对函数表达式和函数声明并非一视同仁.解析器会率先读取函数声明,并使其在执行任何代码之前可用.而函数表达式,则必须等到解析器执行到它所 ...
- JS基础语法---函数作为返回值使用
结论:函数是可以作为返回值使用的 function f1() { console.log("f1函数调用了"); return function() { console.log(& ...
- JS基础语法---函数作为参数使用---回调函数
1. 函数可以作为参数使用, 如果一个函数作为参数, 那么我们说这个参数(函数)可以叫回调函数 2. 只要是看到一个函数作为参数使用了, 那就是回调函数 function sayHi(fn) { co ...
- JS基础语法---函数也是一种数据类型
1. 如何获取某个变量的类型? typeof 2. 函数是有数据类型 ,数据类型:是function function f1() { console.log("我是函数"); } ...
随机推荐
- IDEA2016 maven项目配置Junit
添加插件:File->Settings->Plugins 设置生成模式:File->Settings->Other Settings 修改模板:File->Setting ...
- wepy 小程序云开发
小程序前段时间更新了云开发的功能,刚听到对时候觉得简直是个人开发者对福音,尤其是对我这样对后端不是很懂对前端傻傻,简直不能太方便,就试了下. 体验二维码: 源码:https://github.com/ ...
- 浅析负载均衡的6种算法,Ngnix的5种算法。
浅析负载均衡的6种算法,Ngnix的5种算法.浮生偷闲百家号03-21 10:06关注内容导读其实际效果越来越接近于平均分配调用量到后端的每一台服务器,也就是轮询的结果.源地址哈希的思想是根据获取客 ...
- iReport-5.6.0 新建文件为什么是灰色的?新建项目没有选择项?
从网上下了绿色版和安装版都出现这个问题. 解决:发现原来是有些插件没有激活,进入手动激活就ok了 -->工具-->插件-->已安装 ,选择未激活的手动激活. 激活成功后如下图(和我同 ...
- leetcode42
class Solution: def calLeft(self,height,rightval,left,right): if left>=right: return 0 sums = 0 m ...
- 尚硅谷springboot学习29-docker常用命令和操作
前提是要安装docker,有关docker的安装请参考相关资料,下面来看一下常用的操作命令 1).镜像操作 操作 命令 说明 检索 docker search 关键字 eg:docker search ...
- Session & Cookie 简介
(一)简介 会话(Session)跟踪是Web程序中常用的技术,用来跟踪用户的整个会话.常用的会话跟踪技术是Cookie与Session.Cookie通过在客户端记录信息确定用户身份,Session通 ...
- linux grep (linux查找关键字在php出现的次数)
http://www.th7.cn/system/lin/201508/127681.shtml 查找CleverCode在当前目录以及子目录,所有的php出现大于0的次数. # find -type ...
- 数组中出现次数超过一半的数字(python)
题目描述 数组中有一个数字出现的次数超过数组长度的一半,请找出这个数字.例如输入一个长度为9的数组{1,2,3,2,2,2,5,4,2}.由于数字2在数组中出现了5次,超过数组长度的一半,因此输出2. ...
- mysql修改删除You can't specify target table for update in FROM clause的问题
表中出现重复数据,需要删除重复数据,只保留一条 DELETE FROM crm_participant WHERE id IN ( SELECT c.id cid FROM crm_participa ...