JS初学基础

返回函数多个数字

return[max,min]

• 两个相同的函数后面的会覆盖前面的函数

• 在Javascript中实参的个数和形参的个霰可以不一致

1.如果形参过多会自动填上undefined (了解即可)

2.如果实参过多那么多余的实参会被忽略(函数内部有一个arguments,里面装着所有的实参)

• 函数一旦碰到return就不会在往下执行了函数的结束用return

作用域

全局作用域和局部作用域

整个JS文件就是全局

函数的变量是局部

局部变量或者块级变量,没有let声明的直接赋值当全局变量看

在能访问到的前提,先局部,局部没有找全局

匿名函数

在API部分进一步深化

立即执行函数
html 复制代码
<script>
//let num = 10
//let num 20
//(function (){
// console.log(11)
//})()
(function(){})()


(function(x,y){
console.log(x+y)
})(1,2)


//1.第一种写法
(function (x, y) {
console.log(x + y)
let num = 10
let arr = []
})(1,2);
//(function(){})();
//2.第二种写法
1/(function ({}());
(function (x, y) {
let arr = []
console. log(x + y)
}(1,3));
//(function(){})()
//(function(){}())
</script>

简单案例:输入秒数,转换为时分秒

html 复制代码
<script>
age = age + 1
// L用户输入
let second = +prompt('请输入秒数:')
// 2•封装函数
function getTime(t) {
// console.log(t)//总的秒数
//3、转换
//小时:h=parseInt(总秒数/60/60%24)
//分钟:m=parseInt(总秒数/60%60)
// 秒数: s = parseInt(总秒数 % 60)
h = parseInt(t / 60/ 60% 24)
m = parseInt(t / 60 % 60)
s = parseInt(t % 60)
h=h< 10?'0'+ h : h
m=m<10?'0'+m:m
s = s< 10? '0'+ s: s
// console.log(h, m, s)
return`转换完毕之后是${h}小时${m}分${s}秒`
}
let str = getTime(second)
document.write(str)
</script>

逻辑中断

html 复制代码
<script>
function fn(x, y) {
x = x || 0

y = y || 0
console.log(x + y)
}
fn(l, 2)
fn()
</script>

不仅是形参,还有页面滚动时获取

短路

短路:只存在于&&和II中,当满足一定条件会让右边代码不执行

|------|-------------|
| 符号 | 条件 |
| && | 左边为false就短路 |
| || | 左边为ture就短路 |

原因:通过左边能得到整个式子的结果,因此没必要再判断右边

转换bool型

记忆:' '、0、undefined、null、false、NaN转换为布尔值后都是false,其余则为 true

隐式转换:

1 .有字符串的加法+1,结果是"1"

2 .减法-(像大多数数学运算一样)只能用于数字,它会使空字符串""转换为0

3 . null经过数字转换之后会变为0

4 . undefined经过数字转换之后会变为NaN

javascript 复制代码
console.log('' - 1)                    //-1
console.log( 'pink老师'-1)             //NaN
console.log(null + 1)                 //1
console.log(undefined + 1)            //NaN
console.log(NaN + 1)                  //NaN
相关推荐
阿赛工作室6 分钟前
Vue中onBeforeUnmount不触发的解决方案
前端·javascript·vue.js
码王吴彦祖7 分钟前
顶象 AC 纯算法迁移实战:从补环境到纯算的完整拆解
java·前端·算法
Freak嵌入式7 分钟前
MicroPython LVGL基础知识和概念:显示与多屏管理
开发语言·python·github·php·gui·lvgl·micropython
yu859395812 分钟前
matlab雷达信号与干扰的仿真
开发语言·matlab
前进的李工12 分钟前
LangChain使用AI工具赋能:解锁大语言模型无限潜力
开发语言·人工智能·语言模型·langchain·大模型
yugi98783818 分钟前
C# 串口下载烧写BIN文件工具
开发语言·c#
小叶lr20 分钟前
jenkins打包前端样式丢失/与本地不一致问题
运维·前端·jenkins
浩星25 分钟前
electron系列1:Electron不是玩具,为什么桌面应用需要它?
前端·javascript·electron
ZC跨境爬虫44 分钟前
Scrapy工作空间搭建与目录结构解析:从初始化到基础配置全流程
前端·爬虫·python·scrapy·自动化
小村儿1 小时前
连载04-最重要的Skill---一起吃透 Claude Code,告别 AI coding 迷茫
前端·后端·ai编程