工学结合2019/9/23

2024-02-11 11:10
文章标签 结合 23 2019 工学

本文主要是介绍工学结合2019/9/23,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

调试

alert() console.log()调试方式

debug-断点调试

步骤

​ f12 —>source —>需要调试的文件 --> 设置断点

​ watch:监视变量

​ f10:程序单步执行

​ f8: 跳到下个断点

数组的概念

所谓数组,就是将多个元素(通常是同一类型)按一定顺序排列放到一个集合中,那么这个集合我们就称之为数组。

数组的定义 Array

数组是一个有序的列表,可以在数组中存放任意的数据,并且数组的长度可以动态的调整。

通过数组字面量创建数组

获取数组元素

var arr = ['red', 'blue', 'yellow'];
arr[0];
arr[3]; undefined
格式数组名[下标(索引)]   

遍历数组

遍历:遍及所有,对数组的每一个元素都访问一次就叫遍历。

数组遍历的基本语法:

for(var i = 0; i < arr.length; i++) {// 数组遍历的固定结构
}
for (var i = 0; i < arr.length; i++) {console.log(arr[i]);
}
for (var i = arr.length - 1; i >= 0; i--)

数组中新增元素

var arr = ['red', 'blue', 'yellow'];
arr[0] = 'green';arr[3] = 'pink';

案例

求一组数中的所有数的和和平均值
求一组数中的最大值和最小值,以及所在位置
将字符串数组用|或其他符号分割
要求将数组中的0项去掉,将不为0的值存入一个新的数组,生成新的数组
翻转数组
冒泡排序,从小到大

函数

为什么要有函数

想要在多个地方用到求和,怎么办

1.提高代码复用性

什么是函数

把一段相对独立的具有特定功能的代码块封装起来,形成一个独立实体,就是函数,起个名字(函数名),在后续开发中可以反复调用

函数的作用就是封装一段代码,将来可以重复使用

函数的定义

  • 函数声明
function 函数名() {// 函数体
}
  • 函数表达式
var fn = function () {// 函数体
}

特点: 1.函数声明的时候,函数体并不会执行

​ 2.函数名应该时一个动词

函数的调用

  • 调用函数的语法:
函数名();

可以调用多次

函数的参数

为什么要有参数

​ 1-100的和

​ n-m

  • 语法:
function 函数名(形参1, 形参2, 形参3...) {// 函数体
}
形参:在函数声明时,为了使函数的功能更加灵活,通常设置参数,这个参数没有任何具体的值,仅仅起到一个占位的作用,通常称之为形式参数
实参:在声明时设置了形参,在调用方法就需要传入对应的参数,也就是实际参数,我们称之为实参

案例

  • 判断一个数是否是素数(又叫质数,只能被1和自身整数的数)

函数的返回值

当函数执行完的时候,并不是所有时候都要把结果打印。我们期望函数给我一些反馈(比如计算的结果返回进行后续的运算),这个时候可以让函数返回一些东西。也就是返回值。函数通过return返回一个返回值

返回值语法:

function 函数名(形参1, 形参2, 形参3...) {//函数体return 返回值;
}//可以通过变量来接收这个返回值
var 变量 = 函数名(实参1, 实参2, 实参3...);

函数的调用结果就是返回值,因此我们可以直接对函数调用结果进行操作。

案例

  • 求1!+2!+3!+…+n!

    如果没有显式使用return,也会返回默认值undefined
    当函数执行完return时候,之后的代码就不执行

arguments的使用

JavaScript中,arguments对象是比较特别的一个对象,实际上是当前函数的一个内置属性。也就是说所有函数都内置了一个arguments对象,arguments对象中存储了传递的所有的实参。arguments是一个伪数组,因此及可以进行遍历

  • 案例
求任意个数的最大值
求任意个数的和

函数其它

匿名函数

匿名函数:没有名字的函数

匿名函数如何使用:

将匿名函数赋值给一个变量,这样就可以通过变量进行调用

自调用函数

匿名函数不能通过直接调用来执行,因此可以通过匿名函数的自调用的方式来执行

函数是一种数据类型

function fn() {}
console.log(typeof fn);
  • 函数作为参数

因为函数也是一种类型,可以把函数作为两一个函数的参数,在另一个函数中调用

  • 函数做为返回值

因为函数是一种类型,所以可以把函数可以作为返回值从函数内部返回。

function fn(b) {var a = 10;return function () {alert(a+b);}
}
fn(15)();

代码规范

1.命名规范	变量、函数 的命名 必须要有意义变量一般名词函数一般用动词2.变量规范   操作符的前后要有空格
3.注释规范// 这里是注释
4.空格规范if (true) {}for (var i = 0; i <= 100; i++) {}
5.换行规范var arr = [1, 2, 3, 4];if (a > b) {}for (var i = 0; i < 10; i++) {}function fn() {}

作用域

作用域:变量可以起作用的范围

全局变量和局部变量

  • 全局变量

    在任何地方都可以访问到的变量就是全局变量,对应全局作用域

  • 局部变量

    只在固定的代码片段内可访问到的变量,最常见的例如函数内部。对应局部作用域(函数作用域)

不使用var是全局变量,不推荐使用

块级作用域

任何一对花括号({和})中的语句集都属于一个块,在这之中定义的所有变量在代码块外都是不可见的,我们称之为块级作用域。
在es5之前没有块级作用域的的概念,只有函数作用域,现阶段可以认为JavaScript没有块级作用域

作用域链

只有函数可以制造作用域结构, 那么只要是代码,就至少有一个作用域, 即全局作用域。凡是代码中有函数,那么这个函数就构成另一个作用域。如果函数中还有函数,那么在这个作用域中就又可以诞生一个作用域。将这样的所有的作用域列出来,可以有一个结构: 函数内指向函数外的链式结构。就称作作用域链。
function f1() {var num = 123;function f2() {console.log(num);}f2();
}
var num = 456;
f1();

预解析

JavaScript代码的执行是由浏览器中的JavaScript解析器来执行的。JavaScript解析器执行JavaScript代码的时候,分为两个过程:预解析过程和代码执行过程

对象

为什么要有对象

function printStudent( name age sex grade ...){}function printStudent(Student){console.log(Student.name);
}

什么是对象

现实生活中:万物皆对象,对象是一个具体的事物,一个具体的事物就会有行为和特征。

JavaScript中的对象

JavaScript中的对象其实就是生活中对象的一个抽象
JavaScript的对象是无序属性的集合。其属性可以包含基本值、对象或函数。对象就是一组没有顺序的值。我们可以把JavaScript中的对象想象成键值对,其中值可以是数据和函数。
对象的行为和特征特征---属性行为---方法

对象创建方式

  • 对象字面量
var o = {name: 'zs',age: 18,sex: true,sayHi: function () {console.log(this.name);}
};   
  • new Object()创建对象
var person = new Object();
person.name = 'lisi';
person.age = 35;
person.job = 'actor';
person.sayHi = function() {console.log('Hello,everyBody');
}
  • 自定义构造函数
function Person(name, age, job){this.name = name;this.age = age;this.job = job;this.sayHi = function(){console.log('Hello,everyBody');}
}
var p1 = new Person('张三', 22, 'actor');
  • 工厂模式,设计模式包含工厂模式,单例模式

    function createP(name, job, age) {var person = new Object();person.name = 'lisi';person.age = 35;person.job = 'actor';person.job = 'actor';person.sayHi = function() {console.log('Hello,everyBody');return person;}  
    }
    var preson1 = createP('chen', none, 18);

属性和方法

如果一个变量属于一个对象所有,那么该变量就可以称之为该对象的一个属性,属性一般是名词,用来描述事物的特征
如果一个函数属于一个对象所有,那么该函数就可以称之为该对象的一个方法,方法是动词,描述事物的行为和功能

对象的使用

遍历对象的属性

通过for…in语法可以遍历一个对象

for (var key in obj) {console.log(key + “==” + obj[key]);
} 

删除对象的属性

简单类型和复杂类型的区别

基本类型又叫做值类型,复杂类型又叫做引用类型

值类型:简单数据类型,基本数据类型,在存储时,变量中存储的是值本身,因此叫做值类型。

引用类型:复杂数据类型,在存储是,变量中存储的仅仅是地址(引用),因此叫做引用数据类型。

内置对象

JavaScript中的对象分为3种:内置对象、浏览器对象、自定义对象

JavaScript 提供多个内置对象:Math/Array/Number/String/Boolean…

对象只是带有属性方法的特殊数据类型。

学习一个内置对象的使用,只要学会其常用的成员的使用(通过查文档学习)

可以通过MDN/W3C来查询

内置对象的方法很多,我们只需要知道内置对象提供的常用方法,使用的时候查询文档。

Math对象

Math对象不是构造函数,它具有数学常数和函数的属性和方法,都是以静态成员的方式提供

跟数学相关的运算来找Math中的成员(求绝对值,取整)

Math

演示:Math.PI、Math.random()、Math.floor()/Math.ceil()、Math.round()、Math.abs() 、Math.max()

Math.PI						// 圆周率
Math.random()				// 生成随机数
Math.floor()/Math.ceil()	 // 向下取整/向上取整
Math.round()				// 取整,四舍五入
Math.abs()					// 绝对值
Math.max()/Math.min()		 // 求最大和最小值Math.sin()/Math.cos()		 // 正弦/余弦
Math.power()/Math.sqrt()	 // 求指数次幂/求平方根

Date对象

创建 Date 实例用来处理日期和时间。Date 对象基于1970年1月1日(世界标准时间)起的毫秒数。

  • 获取日期的毫秒形式

  • 日期格式化方法

  • 获取日期指定部分

getTime()  	  // 返回毫秒数和valueOf()结果一样,valueOf()内部调用的getTime()
getMilliseconds() 
getSeconds()  // 返回0-59
getMinutes()  // 返回0-59
getHours()    // 返回0-23
getDay()      // 返回星期几 0周日   6周6
getDate()     // 返回当前月的第几天
getMonth()    // 返回月份,***从0开始***
getFullYear() //返回4位的年份  如 2016

Array对象

  • 创建数组对象的两种方式

    • 字面量方式
    • new Array()
  • 检测一个对象是否是数组

    • instanceof
    • Array.isArray() HTML5中提供的方法,有兼容性问题

    函数的参数,如果要求是一个数组的话,可以用这种方式来进行判断

  • toString()/valueOf()

    • toString() 把数组转换成字符串,逗号分隔每一项
    • valueOf() 返回数组对象本身
  • 数组常用方法:push()、shift()、unshift()、reverse()、sort()、splice()、indexOf()

基本包装类型

为了方便操作基本数据类型,JavaScript还提供了三个特殊的引用类型:String/Number/Boolean

String对象

  • 字符串的不可变

  • 创建字符串对象

  • 字符串对象的常用方法

    字符串所有的方法,都不会修改字符串本身(字符串是不可变的),操作完成会返回一个新的字符串

// 1 字符方法
charAt()    	
charCodeAt()  	
str[0]   		
// 2 字符串操作方法
concat()   		
slice()    		
substring() 	
substr()   		
// 3 位置方法
indexOf()   	
lastIndexOf() 	
// 4 去除空白   
trim()  		
// 5 大小写转换方法
to(Locale)UpperCase() 	
to(Locale)LowerCase() 	

补一张源码,上次的周作业。这是预览图。

在这里插入图片描述

<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><title>Document</title><style type="text/css">* {margin: 0px;padding:0px;}.top{background:url(模仿京东/imges/top背景.jpg) repeat;}.top-header{width: 1190px;height: 80px;margin:0 auto;}.top2{width: 100%;height: 32px;background: url(模仿京东/imges/bg.jpg) repeat;}.dili{width: 1190px;height: 32px;margin:0 auto;}.dili img{margin-top: 3px;float: left;}.dili p{float: left;font-size: 12px;color:#9b9c9e;margin-top: 5px;}.topnav ul li{width: 80px;font-size: 12px;float: right;list-style: none;margin-top: 7px;text-align: center;display: block;}.topnav ul li a{height: 12px;color:#9b9c9e;text-decoration: none;}.topnav ul li a:hover{color:red;}.sx{margin-top: 3px;float: right;border:1px solid #ccc;height: 10px;}/*top结束*/.header{width: 100%;height: 142px;border: 1px solid #ddd;display: block;}.xiaogou{margin: 0 auto;border:1px solid #fff;width: 1190px;height: 142px;position: relative;}.xiaogou img{width: 120px;height: 120px;float: left;margin:10px 40px;}.search{width: 700px;margin-top:25px;margin-left: 248px;position: relative;}.search input{width: 490px;height: 36px;border: 2px solid #f01d12;display: inline-block;}.search button{width:59px;height: 36px;background:url(模仿京东/imges/search.png) no-repeat;background-color: red;border: none;position:absolute;}.search div{height: 34px;width: 120px;float: right;border: 1px solid #9b9c9e;display: block;}.search div a{margin-left:30px;line-height: 30px;text-decoration:none;font-size: 12px;color:red;}.erweima {width: 80px;border: 1px solid #9b9c9e;position: absolute;bottom: 60px;right: 0px;}.erweima img {margin: 10px 10px;width: 60px;  height: 60px;box-shadow: 2px 2px 2px #888888;}.headerul1 {margin-left: 242px;}.headerul1 ul li{font-size: 13px;float: left;list-style: none;text-align: center;display: block;margin: 5px 5px;}.headerul1 ul li a{color: #000;text-decoration: none;}.headerul1 ul li a:hover{color:red;}.headerul1  ul li:first-child a { color:red;}.headerul2 {margin-left: 235px;position: absolute;bottom: 10px;}.headerul2 ul li{margin-left: 15px;font-size: 16px;float: left;list-style: none;margin-top: 7px;text-align: center;display: block;}.headerul2  ul li:first-child a,.headerul2  ul li:nth-child(2) a{color:red;font-weight: bold;}.headerul2 ul li a:hover{color:red;}.headerul2 ul li a{color: #000;text-decoration: none;}/*header结束*/.banner{margin:10px auto;width: 1190px;height: 470px;position: relative;background:#fff;}.zuo{border:1px solid #000;width: 190px;height: 470px;float: left;}.zuo ul li{list-style: none;font-size: 14px;margin: 6px 15px;}.zuo ul li span{margin: 0px 2px;}.zuo ul li a{text-decoration: none;color: #000;}.zuo ul li a:hover{color:red;}.float {width: 1190px;height: 470px;position: relative;}.lunbo{margin-left: 10px; float: left;}.lunbo2 ul li{list-style: none;line-height: 30px;}.lunbo2 ul{}.lunbo2 ul li img{width: 190px;height: 150px;padding-left: 10px;}.you{width:190px;height: 470px;position: absolute;right: 0px;top:0px;overflow: hidden;}</style>
</head>
<body><div class="top"><div class="top-header"><img src="模仿京东/imges/京东头部.webp" ></div><div class="top2"><div class="dili"><img src="模仿京东/imges/地理.jpg" "><p>北京</p> <div class="topnav"><ul><li><a href="#">手机京东</a></li><li><a href="#">网页导航</a><div class="sx"></div></li><li><a href="#">客户服务</a><div class="sx"></div></li><li><a href="#" style="color:red;">企业采购</a><div class="sx"></div></li><li><a href="#">京东会员</a><div class="sx"></div></li><li><a href="#">我的京东</a><div class="sx"></div></li><li><a href="#">我的订单</a><div class="sx"></div></li><li><a href="#" style="color:red;">免费注册</a><div class="sx"></div></li><li><a href="#">你好,请登陆</a></li></ul></div></div></div> </div><div class="header"><div class="xiaogou"><img src="模仿京东/imges/xiaogou.jpg"><div class="search"><input type="search" name="" placeholder="飞利浦"><button></button><div><a href="">我的购物车</a></div></div><div class="erweima"><img src="模仿京东/imges/jd二维码.webp"></div><div class="headerul1"><ul><li><a href="#" >家点超值</a></li><li><a href="#">家装节</a></li><li><a href="#">澳新爆品</a></li><li><a href="#">运动户外</a></li><li><a href="#">9.19抢</a></li><li><a href="#">相机五折</a></li><li><a href="#">华为新品</a></li></ul></div><div class="headerul2"><ul><li><a href="#">秒杀</a></li><li><a href="#">优惠券</a></li><li><a href="#">PLIUS会员</a></li><li><a href="#">品牌闪购</a></li><li><a href="#">拍卖</a></li><li><a href="#">京东时尚</a></li><li><a href="#">京东超市</a></li><li><a href="#">京东生鲜</a></li><li><a href="#">海囤全球</a></li><li><a href="#">京东金融</a></li></ul></div></div></div><div class="banner"><div class="bannnerimg"></div><div class="float"><div class="zuo"><ul><li><a href="#">家用电器</a></li><li><a href="#">手机</a><span>/</span><a href="#">运营商</a><span>/</span><a href="#">数码</a></li><li><a href="#">电脑</a><span>/</span><a href="#">办公</a></li><li><a href="#">家居</a><span>/</span><a href="#">家具</a><span>/</span><a href="#">家装</a><span>/</span><a href="#">厨具</a></li><li><a href="#">男装</a><span>/</span><a href="#">女装</a><span>/</span><a href="#">童装</a><span>/</span><a href="#">内衣</a></li><li><a href="#">美妆</a><span>/</span><a href="#">个人清洁</a><span>/</span><a href="#">宠物</a></li><li><a href="#">女鞋</a><span>/</span><a href="#">箱包</a><span>/</span><a href="#">钟表</a><span>/</span><a href="#">珠宝</a></li><li><a href="#">男鞋</a><span>/</span><a href="#">运动</a><span>/</span><a href="#">户外</a></li><li><a href="#">房产</a><span>/</span><a href="#">汽车</	a><span>/</span><a href="#">汽车用品</a></li><li><a href="#">母婴</a><span>/</span><a href="#">玩具乐器</a></li><li><a href="#">食品</a><span>/</span><a href="#">酒类</	a><span>/</span><a href="#">生鲜</a><span>/</span><a href="#">特产</a></li><li><a href="#">艺术</a><span>/</span><a href="#">礼品鲜花</a><span>/</span><a href="#">农资绿植</a></li><li><a href="#">医药保健</a><span>/</span><a href="#">计生情趣</a></li><li><a href="#">图书</a><span>/</span><a href="#">文娱</	a><span>/</span><a href="#">电子书</a></li><li><a href="#">机票</a><span>/</span><a href="#">酒店</	a><span>/</span><a href="#">旅游</a><span>/</span><a href="#">生活</a></li><li><a href="#">理财</a><span>/</span><a href="#">众筹</	a><span>/</span><a href="#">白条</a><span>/</span><a href="#">保险</a></li><li><a href="#">安装</a><span>/</span><a href="#">维修</	a><span>/</span><a href="#">清洗</a><span>/</span><a href="#">二手</a></li><li><a href="#">工业品</a></li></ul></div><div class="lunbo"><img src="模仿京东/imges/lunbo1.webp"></div><div class="lunbo2"><ul><li><a href=""><img src="模仿京东/imges/lunbo1a.webp"></a></li><li><a href=""><img src="模仿京东/imges/lunbo1a.webp"></a></li><li><a href=""><img src="模仿京东/imges/lunbo1a.webp"></a></li></ul></div><div class="you"><img src="模仿京东/imges/you.jpg"></div></div></div></div>
</body>
</html>

下面是今天下午做的js例子。(源码)

1.反转数组

<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><title></title><script type="text/javascript">var numbers = [1,2,3,4,5,6,7] ;var xin = [] ; for(i = numbers.length-1 ; i >= 0;i--) {xin += numbers[i];}console.log(xin);</script>
</head>
<body></body>
</html>

2.将字符串数组用竖线或其他符号分割

<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><title></title><script type="text/javascript">function sum(n) {var sum = 0 ;for ( var i = 1 ; i <= n ; i++) {sum  += i ;}return sum ;}console.log(sum(100));</script>
</head>
<body></body>
</html>

3.冒泡排序(从小到大)

<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><title>Document</title><script type="text/javascript">var numbers = [2, 4, 1, 7, 9, 6];for (var i = 0; i < numbers.length - 1; i++) {for (var j = 0; j < numbers.length - i; j++) {if (numbers[j] > numbers[j + 1]) {var tmp = numbers[j];numbers[j] = numbers[j + 1];numbers[j + 1] = tmp;}}}for (var i = 0; i < numbers.length; i++) {console.log(numbers[i]);}</script>
</head>
<body>
</body>
</html>

4.函数求圆面积

<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><title>Document</title><script type="text/javascript">function yuan(r) {var yuan = 0 ;yuan = Math.PI * r * r; return yuan ;}console.log(yuan(2));</script>
</head>
<body></body>
</html>

5.将字符串数组用竖线或其他符号分割

<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><title>Document</title><script type="text/javascript">var str = ["A","B","C","D","E","F"] ;var stra = str[0];var s =  "|"for (var i = 1; i < str.length; i++) {stra += s + str[i];}console.log(stra);</script>
</head>
<body></body>
</html>

6.求1-n之间所有数的和

<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><title></title><script type="text/javascript">function sum(n) {var sum = 0 ;for ( var i = 1 ; i <= n ; i++) {sum  += i ;}return sum ;}console.log(sum(100));</script>
</head>
<body></body>
</html>

7. 求2个数中的最大值

<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><title>Document</title><script type="text/javascript">function max(a,b){var z = 0 ;z = a > b ? a : b;return z;}console.log(max(2,1));</script>
</head>
<body></body>
</html>

8.求一组数中的所有数的和和平均值

<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><title>Document</title><script type="text/javascript">var sum = 0 ;var avg = 0 ;var numbers = [10, 20, 30, 40];for(var i = 0;i<numbers.length;i++) {sum += numbers[i];}avg = sum/numbers.length;console.log(sum);console.log(avg);</script>
</head>
<body></body>
</html>

9.求三个数的最大值

<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><title>Document</title><script type="text/javascript">function max(a,b,c){if (a > b && a > c){return a;}if ( b > a && b > c){return b;}else {return c;}}console.log(max(2,1,3));</script>
</head>
<body></body>
</html>

10.将数组内所有的0去除并重新排列

<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><title>Document</title>\<script type="text/javascript">var numbers = [1,2,3,0,4,0,5,6] ;var xin = [];for(var i = 0 ; i <= numbers.length -1;i++){if(numbers[i] != 0 ){xin +=numbers[i];}}console.log(xin);</script>
</head>
<body></body>
</html>

这篇关于工学结合2019/9/23的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/699636

相关文章

使用DeepSeek API 结合VSCode提升开发效率

《使用DeepSeekAPI结合VSCode提升开发效率》:本文主要介绍DeepSeekAPI与VisualStudioCode(VSCode)结合使用,以提升软件开发效率,具有一定的参考价值... 目录引言准备工作安装必要的 VSCode 扩展配置 DeepSeek API1. 创建 API 请求文件2.

龙蜥操作系统Anolis OS-23.x安装配置图解教程(保姆级)

《龙蜥操作系统AnolisOS-23.x安装配置图解教程(保姆级)》:本文主要介绍了安装和配置AnolisOS23.2系统,包括分区、软件选择、设置root密码、网络配置、主机名设置和禁用SELinux的步骤,详细内容请阅读本文,希望能对你有所帮助... ‌AnolisOS‌是由阿里云推出的开源操作系统,旨

Python结合requests和Cheerio处理网页内容的操作步骤

《Python结合requests和Cheerio处理网页内容的操作步骤》Python因其简洁明了的语法和强大的库支持,成为了编写爬虫程序的首选语言之一,requests库是Python中用于发送HT... 目录一、前言二、环境搭建三、requests库的基本使用四、Cheerio库的基本使用五、结合req

如何用Java结合经纬度位置计算目标点的日出日落时间详解

《如何用Java结合经纬度位置计算目标点的日出日落时间详解》这篇文章主详细讲解了如何基于目标点的经纬度计算日出日落时间,提供了在线API和Java库两种计算方法,并通过实际案例展示了其应用,需要的朋友... 目录前言一、应用示例1、天安门升旗时间2、湖南省日出日落信息二、Java日出日落计算1、在线API2

安卓链接正常显示,ios#符被转义%23导致链接访问404

原因分析: url中含有特殊字符 中文未编码 都有可能导致URL转换失败,所以需要对url编码处理  如下: guard let allowUrl = webUrl.addingPercentEncoding(withAllowedCharacters: .urlQueryAllowed) else {return} 后面发现当url中有#号时,会被误伤转义为%23,导致链接无法访问

BUUCTF靶场[web][极客大挑战 2019]Http、[HCTF 2018]admin

目录   [web][极客大挑战 2019]Http 考点:Referer协议、UA协议、X-Forwarded-For协议 [web][HCTF 2018]admin 考点:弱密码字典爆破 四种方法:   [web][极客大挑战 2019]Http 考点:Referer协议、UA协议、X-Forwarded-For协议 访问环境 老规矩,我们先查看源代码

Go 语言中Select与for结合使用break

func test(){i := 0for {select {case <-time.After(time.Second * time.Duration(2)):i++if i == 5{fmt.Println("break now")break }fmt.Println("inside the select: ")}fmt.Println("inside the for: ")}} 执行后

Jenkins--pipeline认识及与RF文件的结合应用

什么是pipeline? Pipeline,就是可运行在Jenkins上的工作流框架,将原本独立运行的单个或多个节点任务连接起来,实现单个任务难以完成的复杂流程编排与可视化。 为什么要使用pipeline? 1.流程可视化显示 2.可自定义流程任务 3.所有步骤代码化实现 如何使用pipeline 首先需要安装pipeline插件: 流水线有声明式和脚本式的流水线语法 流水线结构介绍 Node:

华为23年笔试题

消息传输 题目描述 在给定的 m x n (1 <= m, n <= 1000) 网格地图 grid 中,分布着一些信号塔,用于区域间通信。 每个单元格可以有以下三种状态:  值 0 代表空地,无法传递信号;  值 1 代表信号塔 A,在收到消息后,信号塔 A 可以在 1ms 后将信号发送给上下左右四个方向的信号塔; 值 2 代表信号塔 B,在收到消息后,信号塔 B 可以在 2ms

【vulhub】thinkphp5 2-rce 5.0.23-rce 5-rce 漏洞复现

2-rec 1.启动环境  cd /.../vulhub/thinkphp/2-rce # cd进入2-rce靶场文件环境下docker-compose up -d # docker-compose启动靶场docker ps -a # 查看开启的靶场信息 2.访问192.168.146.136:8080网页 3.构造payload http