2.location 对象:location 是最有用的BOM对象之一,它提供了与当前窗口中加载的文档有关的信息,还提供了一些导航功能。事实上,location 对象是很特别的一个对象,因为它既是window 对象的属性,也是document 对象的属性;换句话说,window.location 和document.location 引用的是同一个对象。location 对象的用处不只表现在它保存着当前文档的信息,还表现在它将URL 解析为独立的片段,让开发人员可以通过不同的属性访问这些片段。下表列出了location 对象的所有属性(注:省略了每个属性前面的location 前缀)。

属性名例子说明
hash#contents返回URL中的hash(#号后跟零或多个字符),如果URL中不包含散列,则返回空字符串
hostwww.wrox.com:80返回服务器名称和端口号(如果有)
hostnamewww.wrox.com返回不带端口号的服务器名称
hrefhttp:/www.wrox.com返回当前加载页面的完整URL。而location对象的toString()方法也返回这个值
pathname/WileyCDA/返回URL中的目录和(或)文件名
port8080返回URL中指定的端口号。如果URL中不包含端口号,则这个属性返回空字符串
protocolhttp:返回页面使用的协议。通常是http:或https:
search?q=javascript返回URL的查询字符串。这个字符串以问号开头
  • 查询字符串参数:虽然通过上面的属性可以访问到location 对象的大多数信息,但其中访问URL 包含的查询字符串的属性并不方便。尽管location.search 返回从问号到URL 末尾的所有内容,但却没有办法逐个访问其中的每个查询字符串参数。为此,可以像下面这样创建一个函数,用以解析查询字符串,然后返回包含所有参数的一个对象:
function getQueryStringArgs(){//取得查询字符串并去掉开头的问号var qs = (location.search.length > 0 ? location.search.substring(1) : ""),//保存数据的对象args = {},//取得每一项items = qs.length ? qs.split("&") : [],item = null,name = null,value = null,//在for 循环中使用i = 0,len = items.length;//逐个将每一项添加到args 对象中for (i=0; i < len; i++){item = items[i].split("=");name = decodeURIComponent(item[0]);value = decodeURIComponent(item[1]);if (name.length) {args[name] = value;}}return args;
}//这个函数的第一步是先去掉查询字符串开头的问号。
当然,前提是location.search 中必须要包含一或多个字符。
//然后,所有参数将被保存在args 对象中,该对象以字面量形式创建。
//接下来,根据和号(&)来分割查询字符串,并返回name=value 格式的字符串数组。
//for 循环会迭代这个数组,然后根据等于号分割每一项,返回第一项为参数名,第二项为参数值的数组。
//再使用decodeURIComponent()分别解码name 和value(因为查询字符串应该是被编码过的)。
//最后,将name 作为args 对象的属性,将value 作为相应属性的值。下面给出了使用这个函数的示例。
//假设查询字符串是?q=javascript&num=10var args = getQueryStringArgs();
alert(args["q"]); //"javascript"
alert(args["num"]); //"10"//可见,每个查询字符串参数都成了返回对象的属性。这样就极大地方便了对每个参数的访问。
  • 位置操作:使用location 对象可以通过很多方式来改变浏览器的位置。首先,也是最常用的方式,就是使用assign()方法并为其传递一个URL,如下所示。
location.assign("http://www.wrox.com");//这样,就可以立即打开新URL 并在浏览器的历史记录中生成一条记录。
//如果是将location.href或window.location 设置为一个URL 值,也会以该值调用assign()方法。
//例如,下列两行代码与显式调用assign()方法的效果完全一样。window.location = "http://www.wrox.com";
location.href = "http://www.wrox.com";//在这些改变浏览器位置的方法中,最常用的是设置location.href 属性。
//另外,修改location 对象的其他属性也可以改变当前加载的页面。
//下面的例子展示了通过将hash、search、hostname、pathname 和port 属性设置为新值来改变URL。//假设初始URL 为http://www.wrox.com/WileyCDA/
//将URL 修改为"http://www.wrox.com/WileyCDA/#section1"
location.hash = "#section1";//将URL 修改为"http://www.wrox.com/WileyCDA/?q=javascript"
location.search = "?q=javascript";//将URL 修改为"http://www.yahoo.com/WileyCDA/"
location.hostname = "www.yahoo.com";//将URL 修改为"http://www.yahoo.com/mydir/"
location.pathname = "mydir";//将URL 修改为"http://www.yahoo.com:8080/WileyCDA/"
location.port = 8080;//每次修改location 的属性(hash 除外),页面都会以新URL 重新加载。//在IE8、Firefox 1、Safari 2+、Opera 9+和Chrome 中,
//修改hash 的值会在浏览器的历史记录中生成一条新记录。
//在IE 的早期版本中,hash 属性不会在用户单击“后退”和“前进”按钮时被更新,
//而只会在用户单击包含hash 的URL 时才会被更新。

当通过上述任何一种方式修改URL 之后,浏览器的历史记录中就会生成一条新记录,因此用户通过单击“后退”按钮都会导航到前一个页面。要禁用这种行为,可以使用replace()方法。这个方法只接受一个参数,即要导航到的URL;结果虽然会导致浏览器位置改变,但不会在历史记录中生成新记录。在调用replace()方法之后,用户不能回到前一个页面,来看下面的例子

<!DOCTYPE html>
<html><head><title>You won't be able to get back here</title></head>
<body><p>Enjoy this page for a second, because you won't be coming back here.</p><script type="text/javascript">setTimeout(function () {location.replace("http://www.wrox.com/");}, 1000);</script>
</body>
</html>//如果将这个页面加载到浏览器中,浏览器就会在1 秒钟后重新定向到www.wrox.com。
//然后,“后退”按钮将处于禁用状态,如果不重新输入完整的URL,则无法返回示例页面。

与位置有关的最后一个方法是reload(),作用是重新加载当前显示的页面。如果调用reload()时不传递任何参数,页面就会以最有效的方式重新加载。也就是说,如果页面自上次请求以来并没有改变过,页面就会从浏览器缓存中重新加载。如果要强制从服务器重新加载,则需要像下面这样为该方法传递参数true。

location.reload(); //重新加载(有可能从缓存中加载)
location.reload(true); //重新加载(从服务器重新加载)//位于reload()调用之后的代码可能会也可能不会执行,这要取决于网络延迟或系统资源等因素。
//为此,最好将reload()放在代码的最后一行。

3.navigator 对象:最早由Netscape Navigator 2.0 引入的navigator 对象,现在已经成为识别客户端浏览器的事实标准。虽然其他浏览器也通过其他方式提供了相同或相似的信息(例如,IE 中的window.clientInformation和Opera 中的window.opera),但navigator 对象却是所有支持JavaScript 的浏览器所共有的。与其他BOM 对象的情况一样,每个浏览器中的navigator 对象也都有一套自己的属性。下表列出了存在于所有浏览器中的属性和方法,以及支持它们的浏览器版本。

属性或方法说明IEFirefoxSafari/ChromeOpera
appCodeName浏览器的名称。通常都是Mozilla,即使在非Mozilla浏览器中也是如此3.0+1.0+1.0+7.0+
appMinorVersion次版本信息4.0+9.5+
appName完整的浏览器名称3.0+1.0+1.0+7.0+
appVersion浏览器的版本。一般不与实际的浏览器版本对应3.0+1.0+1.0+7.0+
buildID浏览器编译版本2.0+
cookieEnabled表示cookie是否启用4.0+1.0+1.0+7.0+
cpuClass客户端计算机中使用的CPU类型(x86、68K、Alpha、PPC或Other)4.0+
javaEnabled()表示当前浏览器中是否启用了Java4.0+1.0+1.0+7.0+
language浏览器的主语言1.0+1.0+7.0+
mimeTypes在浏览器中注册的MIME类型数组4.0+1.0+1.0+7.0+
onLine表示浏览器是否连接到了因特网4.0+1.0+9.5+
opsProfile似乎早就不用了。查不到相关文档4.0+
oscpu客户端计算机的操作系统或使用的CPU1.0+
platform浏览器所在的系统平台4.0+1.0+1.0+7.0+
plugins浏览器中安装的插件信息的数组4.0+1.0+1.0+7.0+
preference()设置用户的首选项1.5+
product产品名称(如Gecko)1.0+1.0+
productSub关于产品的次要信息(如Gecko的版本)1.0+1.0+
register-ContentHandler()针对特定的MIME类型将一个站点注册为处理程序2.0+
register-ProtocolHandler()针对特定的协议将一个站点注册为处理程序2
securityPolicy

已经废弃。安全策略的名称。

为了与Netscape Navigator4向后兼容而保留下来

1.0+
systemLanguage操作系统的语言4.0+
taintEnabled()

已经废弃。表示是否允许变量被修改(taint)。

为了与NetscapeNavigator3向后兼容而保留下来4.0+

1.0+7.0+ 
userAgent浏览器的用户代理字符串3.0+1.0+1.0+7.0+
userLanguage操作系统的默认语言4.0+7.0+
userProfile借以访问用户个人信息的对象4.0+
vendor浏览器的品牌1.0+1.0+
vendorSub有关供应商的次要信息1.0+1.0+

表中的这些navigator 对象的属性通常用于检测显示网页的浏览器类型。 

  • 检测插件:检测浏览器中是否安装了特定的插件是一种最常见的检测例程。对于非IE 浏览器,可以使用plugins 数组来达到这个目的。该数组中的每一项都包含下列属性。

name:插件的名字。

description:插件的描述。

filename:插件的文件名。

length:插件所处理的MIME 类型数量。

//一般来说,name 属性中会包含检测插件必需的所有信息,但有时候也不完全如此。
//在检测插件时,需要像下面这样循环迭代每个插件并将插件的name 与给定的名字进行比较。//检测插件(在IE 中无效)
function hasPlugin(name){name = name.toLowerCase();for (var i=0; i < navigator.plugins.length; i++){if (navigator. plugins [i].name.toLowerCase().indexOf(name) > -1){return true;}}return false;
}
//检测Flash
alert(hasPlugin("Flash"));
//检测QuickTime
alert(hasPlugin("QuickTime"));//这个hasPlugin()函数接受一个参数:要检测的插件名。第一步是将传入的名称转换为小写形式,以便于比较。
//然后,迭代plugins数组,通过indexOf()检测每个name属性,以确定传入的名称是否出现在字符串的某个地方
//比较的字符串都使用小写形式,避免因大小写不一致导致的错误。而传入的参数应该尽可能具体,以避免混淆。
//应该说,像Flash 和QuickTime 这样的字符串就比较具体了,不容易导致混淆。
//在Firefox、Safari、Opera 和Chrome 中可以使用这种方法来检测插件。

每个插件对象本身也是一个MimeType 对象的数组,这些对象可以通过方括号语法来访问。每个MimeType 对象有4 个属性:包含MIME 类型描述的description、回指插件对象的enabledPlugin、表示与MIME 类型对应的文件扩展名的字符串suffixes(以逗号分隔)和表示完整MIME 类型字符串的type。

检测IE 中的插件比较麻烦,因为IE 不支持Netscape 式的插件。在IE 中检测插件的唯一方式就是使用专有的ActiveXObject 类型,并尝试创建一个特定插件的实例。IE 是以COM对象的方式实现插件的,而COM对象使用唯一标识符来标识。因此,要想检查特定的插件,就必须知道其COM标识符。例如,Flash 的标识符是ShockwaveFlash.ShockwaveFlash。知道唯一标识符之后,就可以编写类似下面的函数来检测IE 中是否安装相应插件了。

//检测IE 中的插件
function hasIEPlugin(name){try {new ActiveXObject(name);return true;} catch (ex){return false;}
}
//检测Flash
alert(hasIEPlugin("ShockwaveFlash.ShockwaveFlash"));
//检测QuickTime
alert(hasIEPlugin("QuickTime.QuickTime"));//在这个例子中,函数hasIEPlugin()只接收一个COM 标识符作为参数。
//在函数内部,首先会尝试创建一个COM 对象的实例。
//之所以要在try-catch 语句中进行实例化,是因为创建未知COM 对象会导致抛出错误。
//这样,如果实例化成功,则函数返回true;否则,如果抛出了错误,则执行catch块,结果就会返回false。
//例子最后检测IE 中是否安装了Flash 和QuickTime 插件。

 鉴于检测这两种插件的方法差别太大,因此典型的做法是针对每个插件分别创建检测函数,而不是使用前面介绍的通用检测方法。来看下面的例子。

//检测所有浏览器中的Flash
function hasFlash(){var result = hasPlugin("Flash");if (!result){result = hasIEPlugin("ShockwaveFlash.ShockwaveFlash");}return result;
}//检测所有浏览器中的QuickTime
function hasQuickTime(){var result = hasPlugin("QuickTime");if (!result){result = hasIEPlugin("QuickTime.QuickTime");}return result;
}
//检测Flash
alert(hasFlash());
//检测QuickTime
alert(hasQuickTime());//上面代码中定义了两个函数:hasFlash()和hasQuickTime()。
//每个函数都是先尝试使用不针对IE 的插件检测方法。
//如果返回了false(在IE 中会这样),那么再使用针对IE 的插件检测方法。
//如果IE 的插件检测方法再返回false,则整个方法也将返回false。
//只要任何一次检测返回true,整个方法都会返回true。

plugins 集合有一个名叫refresh()的方法,用于刷新plugins 以反映最新安装的插件。这个方法接收一个参数:表示是否应该重新加载页面的一个布尔值。如果将这个值设置为true,则会重新加载包含插件的所有页面;否则,只更新plugins集合,不重新加载页面。

  • 注册处理程序:Firefox 2 为navigator 对象新增了registerContentHandler()和registerProtocolHandler()方法(这两个方法是在HTML5 中定义的,相关内容将在第22 章讨论)。这两个方法可以让一个站点指明它可以处理特定类型的信息。随着RSS 阅读器和在线电子邮件程序的兴起,注册处理程序就为像使用桌面应用程序一样默认使用这些在线应用程序提供了一种方式。

其中,registerContentHandler()方法接收三个参数:要处理的MIME 类型、可以处理该MIME类型的页面的URL 以及应用程序的名称。举个例子,要将一个站点注册为处理RSS 源的处理程序,可以使用如下代码。


navigator.registerContentHandler("application/rss+xml",
"http://www.somereader.com?feed=%s", "Some Reader");//第一个参数是RSS 源的MIME 类型。
//第二个参数是应该接收RSS 源URL 的URL,其中的%s 表示RSS 源URL,由浏览器自动插入。
//当下一次请求RSS 源时,浏览器就会打开指定的URL,而相应的Web 应用程序将以适当方式来处理该请求。

Firefox 4 及之前版本只允许在registerContentHandler()方法中使用三个MIME 类型:application/rss+xml、application/atom+xml 和application/vnd.mozilla.maybe. feed。这三个MIME 类型的作用都一样,即为RSS 或ATOM新闻源(feed)注册处理程序。

类似的调用方式也适用于registerProtocolHandler()方法,它也接收三个参数:要处理的协议(例如,mailto 或ftp)、处理该协议的页面的URL 和应用程序的名称。例如,要想将一个应用程序注册为默认的邮件客户端,可以使用如下代码。

navigator.registerProtocolHandler("mailto",
"http://www.somemailclient.com?cmd=%s", "Some Mail Client");//这个例子注册了一个mailto 协议的处理程序,该程序指向一个基于Web 的电子邮件客户端。
//同样,第二个参数仍然是处理相应请求的URL,而%s 则表示原始的请求。//Firefox 2 虽然实现了registerProtocolHandler(),但该方法还不能用。
//Firefox 3 完整实现这个方法。

4.screen 对象:JavaScript 中有几个对象在编程中用处不大,而screen 对象就是其中之一。screen 对象基本上只用来表明客户端的能力,其中包括浏览器窗口外部的显示器的信息,如像素宽度和高度等。每个浏览器中的screen 对象都包含着各不相同的属性,下表列出了所有属性及支持相应属性的浏览器。

属性说明IEFirefoxSafari/ChromeOpera
availHeight屏幕的像素高度减系统部件高度之后的值(只读)
availLeft未被系统部件占用的最左侧的像素值(只读)  
availTop未被系统部件占用的最上方的像素值(只读)  
availWidth屏幕的像素宽度减系统部件宽度之后的值(只读)
bufferDepth读、写用于呈现屏外位图的位数   
colorDepth用于表现颜色的位数;多数系统都是32(只读)
deviceXDPI屏幕实际的水平DPI(只读)   
deviceYDPI屏幕实际的垂直DPI(只读)   
fontSmoothingEnabled表示是否启用了字体平滑(只读)   
height屏幕的像素高度
left当前屏幕距左边的像素距离   
logicalXDPI屏幕逻辑的水平DPI(只读)   
logicalYDPI屏幕逻辑的垂直DPI(只读)   
pixelDepth屏幕的位深(只读) 
top当前屏幕距上边的像素距离   
updateInterval读、写以毫秒表示的屏幕刷新时间间隔   
width屏幕的像素宽度

 这些信息经常集中出现在测定客户端能力的站点跟踪工具中,但通常不会用于影响功能。不过,有时候也可能会用到其中的信息来调整浏览器窗口大小,使其占据屏幕的可用空间,例如:

window.resizeTo(screen.availWidth, screen.availHeight);

前面曾经提到过,许多浏览器都会禁用调整浏览器窗口大小的能力,因此上面这行代码不一定在所有环境下都有效。
涉及移动设备的屏幕大小时,情况有点不一样。运行iOS 的设备始终会像是把设备竖着拿在手里一样,因此返回的值是768×1024。而Android 设备则会相应调用screen.width 和screen.height 的值。

5.history 对象:history 对象保存着用户上网的历史记录,从窗口被打开的那一刻算起。因为history 是window对象的属性,因此每个浏览器窗口、每个标签页乃至每个框架,都有自己的history 对象与特定的window 对象关联。出于安全方面的考虑,开发人员无法得知用户浏览过的URL。不过,借由用户访问过的页面列表,同样可以在不知道实际URL 的情况下实现后退和前进。

使用go()方法可以在用户的历史记录中任意跳转,可以向后也可以向前。这个方法接受一个参数,表示向后或向前跳转的页面数的一个整数值。负数表示向后跳转(类似于单击浏览器的“后退”按钮),正数表示向前跳转(类似于单击浏览器的“前进”按钮)。来看下面的例子。

//后退一页
history.go(-1);
//前进一页
history.go(1);
//前进两页
history.go(2);//也可以给go()方法传递一个字符串参数,此时浏览器会跳转到历史记录中包含该字符串的第一个位置
//可能后退,也可能前进,具体要看哪个位置最近。
//如果历史记录中不包含该字符串,那么这个方法什么也不做,例如://跳转到最近的wrox.com 页面
history.go("wrox.com");
//跳转到最近的nczonline.net 页面
history.go("nczonline.net");//另外,还可以使用两个简写方法back()和forward()来代替go()。
//顾名思义,这两个方法可以模仿浏览器的“后退”和“前进”按钮。//后退一页
history.back();
//前进一页
history.forward();
//除了上述几个方法外,history 对象还有一个length 属性,保存着历史记录的数量。
//这个数量包括所有历史记录,即所有向后和向前的记录。
//对于加载到窗口、标签页或框架中的第一个页面而言,history.length 等于0。
//通过像下面这样测试该属性的值,可以确定用户是否一开始就打开了你的页面。if (history.length == 0){//这应该是用户打开窗口后的第一个页面
}
//虽然history 并不常用,但在创建自定义的“后退”和“前进”按钮,
//以及检测当前页面是不是用户历史记录中的第一个页面时,还是必须使用它。

当页面的URL 改变时,就会生成一条历史记录。在IE8 及更高版本、Opera、Firefox、Safari 3 及更高版本以及Chrome 中,这里所说的改变包括URL 中hash 的变化(因此,设置location.hash 会在这些浏览器中生成一条新的历史记录)。

查看全文
如若内容造成侵权/违法违规/事实不符,请联系编程学习网邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!

相关文章

  1. 常见的机器学习算法(十)决策树分类器

    直接调用sklearn的API:from sklearn import tree #决策树分类器# module = tree.DecisionTreeClassifier(criterion=gini) module.fit(x, y) module.score(x, y) module.predict(test)整体代码:from sklearn.datasets import load_iris from sk…...

    2024/4/24 7:35:13
  2. C++ 反汇编/栈帧

    文章目录查看 C++ ASM在线 C++ 反汇编g++ -SVS 调试时断点查看反汇编信息VS 在项目属性的文件输出源码+汇编Debug 下的:[ProjectName].asmRelease 下的:[ProjectName].asmVS 调试数据模块进程内存寄存器在内存中的一些字符表信息编译出来的ASM文件通常包含的数据基本分段/分块…...

    2024/4/24 7:35:11
  3. 数据库(MYSQL-SQL分组函数)

    select avg(A),min(A)-from table-where A like %D%...

    2024/4/24 7:35:21
  4. windows---mysql5.7定时备份

    创建一个脚本:@echo off set "Ymd=%date:~,4%%date:~5,2%%date:~8,2%%time:~0,2%%time:~3,2%%time:~6,2%" cd D:\phpStudy\MySQL\bin\ mysqldump --opt --single-transaction=TRUE --user=root --password=root --host=127.0.0.1 --protocol=tcp --port=3306 --defa…...

    2024/4/24 7:35:10
  5. 使用C#操作Excel(读写包含wps)

    转发https://www.cnblogs.com/kenjiang/p/10790652.htmlC#读写Excel的几种方法1 使用Office自带的库前提是本机须安装office才能运行,且不同的office版本之间可能会有兼容问题,从Nuget下载 Microsoft.Office.Interop.Excel读写代码如下:1 using Microsoft.Office.Interop.Ex…...

    2024/4/24 7:35:16
  6. 用AI改变传统招聘模式:看人工智能是如何改变招聘实践的?

    人工智能是当今技术讨论的重中之重。该领域的进步已经改变了传统上的工作方式。让我们以招聘过程为例。来看看我们实施人工智能,可以在招聘活动中有哪些新内容? 说人工智能正在与人力资源一起工作似乎是矛盾的,但是几乎80%的高管认为人工智能可以提高他们的整体生产力和性能…...

    2024/4/24 7:35:09
  7. 【SQL数据库笔记】手机的前三位后四位快速检索客户信息,数据库中匹配中间四位,数据库存储过程代码

    使用存储过程示例代码:declare @No1 varchar(20)--- declare @NO2 varchar(20)--- select @No1=CardID from CardInfo where customerID in (select customerID from userInfo where customerName=李四) select @No2=CardID from CardInfo where customerID in (select cust…...

    2024/4/24 7:35:07
  8. JS笔记02-数组

    创建一维数组:方法1 var arr=[元素1,元素2......] 其实也可以这样创建空数组 var arr=[]; 方法2 var arr=new Array();指定访问某个元素:数组名[下标号], 下标号默认是从0 开始编号js的数组可以动态的增长;js中,通过一个函数传递数组,默认是引用传递遍历数组for(var i=0;i…...

    2024/4/24 7:35:05
  9. javasejavase基础篇学习之接口

    关键字: interface jdk8以后 除了抽象方法,还允许有普通方法 普通方法前需加default 可重写也可以不重写 新特性还有静态方法...

    2024/4/24 7:35:05
  10. tensorflow中RMSprop优化器运用

    tensorflow中RMSprop优化器运用RMSprop优化器引用API:tf.keras.optimizers.RMSprop代码实现:#RMSpropbeta = 0.9 #定义超参数,经验值为0.9v_w = beta * v_w + (1 - beta) * tf.square(grads[0]) #求二阶动量v_wv_b = beta * v_b + (1 - beta) * tf.square(grads[1]) #求二阶…...

    2024/4/16 19:33:44
  11. week13作业

    C - TT 的奖励(必做)解题思路: 对于这道题目来讲,感觉算是一道比较经典的dp问题,但是,自己一开始没有想到利用dp解决,在这一点上,说明自己对于dp的问题感触不够深。当看到这道题目时,首先出现在自己脑海中的是之前做过的两道题目——即宇宙射线问题与矩阵选数问题,总…...

    2024/4/16 19:33:44
  12. spring boot项目中验证码功能实现

    写spring boot项目登录功能是,验证码功能肯定是不能少的,这里将介绍一个工具来生成二维码,kaptchaKaptcha使用步骤导入jar包编写Kaptcha配置类生成随机字符串和验证码图片 导入jar包<dependency><groupId>com.github.penggle</groupId><artifactId>…...

    2024/4/16 19:33:32
  13. 几何问题中的分治法

    几何问题中的分治法 1.最近对问题 问题描述:设p1=(x1,y1),p2=(x2,y2),…,pn=(xn,yn)一共n个点构成点集S,最近点对问题就是找出集合中距离最近的两个点,严格来说最近点对可能多于一个,但我们简单起见只找出一对即可。算法思路:(1)划分:将集合S分成两个子集S1和S2,根据平衡子…...

    2024/4/19 17:17:20
  14. Java Web 笔记

    JAVA WEB笔记通信结构HTML基础JSP(Java Server Pager)JSP基本元素注释 通信结构 C/S(客户机/服务器)将APP下载到PC与Server通信 B/S(浏览器/服务器): 用户输入—>PC—>向Web Server发送请求—>Web Server访问数据库服务器—>数据库服务器向Web Server返回结果…...

    2024/4/24 7:35:03
  15. android开发之相对布局

    android开发之相对布局关键词代码展示成果展示 关键词 RelativeLayut(相对布局);centerInParent(相对父元素居中);above(相对目标元素向上);below(相对目标元素向下) 代码展示成果展示...

    2024/4/24 7:35:05
  16. Qt文档阅读笔记-重现GUI事件进行单元测试

    主要的逻辑是,存储Widget事件,然后在Test中重放如下,在私有槽函数中测试函数如果要加模拟,需要在后面添加_data()class TestGui: public QObject {Q_OBJECTprivate slots:void testGui_data();void testGui(); };下面的代码中,QTest::addColumn为添加列,第一个为重现的事…...

    2024/4/24 7:35:01
  17. Jupyter notebook:由于GPU内存不足的原因,可能导致的错误提示

    1、Failed to get convolution algorithm. This is probably because cuDNN failed2、tensorflow:OOM when allocating tensor with shape[225,256,256,36] and type float on /job:localhost/re解决办法:1.减少卷积核的数量2.减小输入图像的尺寸3.减少输入图像批次的大小4.关…...

    2024/4/24 7:35:02
  18. 初识focal loss

    意义 消除正负样本不平衡的问题,主要应用于one-stage的任务中,由于正样本(目标)在图像中的比重远远低于负样本(背景),经过NMS后还是会存在大量的负样本,这样会使得负样本占LOSS的比重远大于正样本,LOSS可能会朝着负样本的方向优化。一个极端的例子,如果数据中只有一个…...

    2024/4/24 7:35:06
  19. 论文阅读笔记《Image Deformation Meta-Networks for One-Shot Learning》

    核心思想本文是通过数据增强的形式实现小样本学习任务,采取的方式比较直接,通过对图片进行变形来实现数据集的扩充。作者首先为我们展示了一组图片,如下图所示可以看到上述图片虽然经过了多种变形(如虚化,拼接,遮挡),但由于依旧保留了重要的语义信息,我们还是非常容易…...

    2024/4/24 7:34:58
  20. 微信开发---授权登录

    记录下微信开发遇到的遇到的几种授权,待继续填充一 开放平台-网站应用详情阅读 官方文档1.1 获取授权 access_token 以及标识 openid 。method: geturl: https://api.weixin.qq.com/sns/oauth2/access_token?appid=APPID&secret=SECRET&code=CODE&grant_type=auth…...

    2024/4/24 7:34:57

最新文章

  1. MySQL数据库创建用户并授权查询某个表

    一.背景 公司的师带徒任务&#xff0c;让徒弟做了一个小的应用。其中一个表的数据要抽取到分析软件中&#xff0c;需要创建一个数据库的用户&#xff0c;并授权查询某个表。考虑类似场景多&#xff0c;就简单记录一下这个sql。 二.环境 操作系统&#xff1a;windows server 20…...

    2024/4/27 3:48:03
  2. 梯度消失和梯度爆炸的一些处理方法

    在这里是记录一下梯度消失或梯度爆炸的一些处理技巧。全当学习总结了如有错误还请留言&#xff0c;在此感激不尽。 权重和梯度的更新公式如下&#xff1a; w w − η ⋅ ∇ w w w - \eta \cdot \nabla w ww−η⋅∇w 个人通俗的理解梯度消失就是网络模型在反向求导的时候出…...

    2024/3/20 10:50:27
  3. 谷粒商城实战(008 缓存)

    Java项目《谷粒商城》架构师级Java项目实战&#xff0c;对标阿里P6-P7&#xff0c;全网最强 总时长 104:45:00 共408P 此文章包含第151p-第p157的内容 简介 数据库承担落盘&#xff08;持久化&#xff09;工作 拿map做缓存 这种是本地缓存&#xff0c;会有一些问题 分布…...

    2024/4/23 6:23:00
  4. Linux——gdb

    gdb调试 (1)debug版本: 在编译阶段会加入某些调试信息; 调试信息是在编译的过程中加入到中间文件.o文件的; gcc -c main.c -g:生成包含调试信息的中间文件 gcc -o main main.o 一步执行:gcc -o main main.c -g (1) (2)release版本: 发行版本,没有调试信息; gcc默认生成relea…...

    2024/4/26 21:20:03
  5. 【外汇早评】美通胀数据走低,美元调整

    原标题:【外汇早评】美通胀数据走低,美元调整昨日美国方面公布了新一期的核心PCE物价指数数据,同比增长1.6%,低于前值和预期值的1.7%,距离美联储的通胀目标2%继续走低,通胀压力较低,且此前美国一季度GDP初值中的消费部分下滑明显,因此市场对美联储后续更可能降息的政策…...

    2024/4/26 18:09:39
  6. 【原油贵金属周评】原油多头拥挤,价格调整

    原标题:【原油贵金属周评】原油多头拥挤,价格调整本周国际劳动节,我们喜迎四天假期,但是整个金融市场确实流动性充沛,大事频发,各个商品波动剧烈。美国方面,在本周四凌晨公布5月份的利率决议和新闻发布会,维持联邦基金利率在2.25%-2.50%不变,符合市场预期。同时美联储…...

    2024/4/26 20:12:18
  7. 【外汇周评】靓丽非农不及疲软通胀影响

    原标题:【外汇周评】靓丽非农不及疲软通胀影响在刚结束的周五,美国方面公布了新一期的非农就业数据,大幅好于前值和预期,新增就业重新回到20万以上。具体数据: 美国4月非农就业人口变动 26.3万人,预期 19万人,前值 19.6万人。 美国4月失业率 3.6%,预期 3.8%,前值 3…...

    2024/4/26 23:05:52
  8. 【原油贵金属早评】库存继续增加,油价收跌

    原标题:【原油贵金属早评】库存继续增加,油价收跌周三清晨公布美国当周API原油库存数据,上周原油库存增加281万桶至4.692亿桶,增幅超过预期的74.4万桶。且有消息人士称,沙特阿美据悉将于6月向亚洲炼油厂额外出售更多原油,印度炼油商预计将每日获得至多20万桶的额外原油供…...

    2024/4/25 18:39:23
  9. 【外汇早评】日本央行会议纪要不改日元强势

    原标题:【外汇早评】日本央行会议纪要不改日元强势近两日日元大幅走强与近期市场风险情绪上升,避险资金回流日元有关,也与前一段时间的美日贸易谈判给日本缓冲期,日本方面对汇率问题也避免继续贬值有关。虽然今日早间日本央行公布的利率会议纪要仍然是支持宽松政策,但这符…...

    2024/4/25 18:39:22
  10. 【原油贵金属早评】欧佩克稳定市场,填补伊朗问题的影响

    原标题:【原油贵金属早评】欧佩克稳定市场,填补伊朗问题的影响近日伊朗局势升温,导致市场担忧影响原油供给,油价试图反弹。此时OPEC表态稳定市场。据消息人士透露,沙特6月石油出口料将低于700万桶/日,沙特已经收到石油消费国提出的6月份扩大出口的“适度要求”,沙特将满…...

    2024/4/25 18:39:22
  11. 【外汇早评】美欲与伊朗重谈协议

    原标题:【外汇早评】美欲与伊朗重谈协议美国对伊朗的制裁遭到伊朗的抗议,昨日伊朗方面提出将部分退出伊核协议。而此行为又遭到欧洲方面对伊朗的谴责和警告,伊朗外长昨日回应称,欧洲国家履行它们的义务,伊核协议就能保证存续。据传闻伊朗的导弹已经对准了以色列和美国的航…...

    2024/4/26 21:56:58
  12. 【原油贵金属早评】波动率飙升,市场情绪动荡

    原标题:【原油贵金属早评】波动率飙升,市场情绪动荡因中美贸易谈判不安情绪影响,金融市场各资产品种出现明显的波动。随着美国与中方开启第十一轮谈判之际,美国按照既定计划向中国2000亿商品征收25%的关税,市场情绪有所平复,已经开始接受这一事实。虽然波动率-恐慌指数VI…...

    2024/4/25 16:48:44
  13. 【原油贵金属周评】伊朗局势升温,黄金多头跃跃欲试

    原标题:【原油贵金属周评】伊朗局势升温,黄金多头跃跃欲试美国和伊朗的局势继续升温,市场风险情绪上升,避险黄金有向上突破阻力的迹象。原油方面稍显平稳,近期美国和OPEC加大供给及市场需求回落的影响,伊朗局势并未推升油价走强。近期中美贸易谈判摩擦再度升级,美国对中…...

    2024/4/26 16:00:35
  14. 【原油贵金属早评】市场情绪继续恶化,黄金上破

    原标题:【原油贵金属早评】市场情绪继续恶化,黄金上破周初中国针对于美国加征关税的进行的反制措施引发市场情绪的大幅波动,人民币汇率出现大幅的贬值动能,金融市场受到非常明显的冲击。尤其是波动率起来之后,对于股市的表现尤其不安。隔夜美国股市出现明显的下行走势,这…...

    2024/4/25 18:39:16
  15. 【外汇早评】美伊僵持,风险情绪继续升温

    原标题:【外汇早评】美伊僵持,风险情绪继续升温昨日沙特两艘油轮再次发生爆炸事件,导致波斯湾局势进一步恶化,市场担忧美伊可能会出现摩擦生火,避险品种获得支撑,黄金和日元大幅走强。美指受中美贸易问题影响而在低位震荡。继5月12日,四艘商船在阿联酋领海附近的阿曼湾、…...

    2024/4/25 18:39:16
  16. 【原油贵金属早评】贸易冲突导致需求低迷,油价弱势

    原标题:【原油贵金属早评】贸易冲突导致需求低迷,油价弱势近日虽然伊朗局势升温,中东地区几起油船被袭击事件影响,但油价并未走高,而是出于调整结构中。由于市场预期局势失控的可能性较低,而中美贸易问题导致的全球经济衰退风险更大,需求会持续低迷,因此油价调整压力较…...

    2024/4/26 19:03:37
  17. 氧生福地 玩美北湖(上)——为时光守候两千年

    原标题:氧生福地 玩美北湖(上)——为时光守候两千年一次说走就走的旅行,只有一张高铁票的距离~ 所以,湖南郴州,我来了~ 从广州南站出发,一个半小时就到达郴州西站了。在动车上,同时改票的南风兄和我居然被分到了一个车厢,所以一路非常愉快地聊了过来。 挺好,最起…...

    2024/4/26 22:01:59
  18. 氧生福地 玩美北湖(中)——永春梯田里的美与鲜

    原标题:氧生福地 玩美北湖(中)——永春梯田里的美与鲜一觉醒来,因为大家太爱“美”照,在柳毅山庄去寻找龙女而错过了早餐时间。近十点,向导坏坏还是带着饥肠辘辘的我们去吃郴州最富有盛名的“鱼头粉”。说这是“十二分推荐”,到郴州必吃的美食之一。 哇塞!那个味美香甜…...

    2024/4/25 18:39:14
  19. 氧生福地 玩美北湖(下)——奔跑吧骚年!

    原标题:氧生福地 玩美北湖(下)——奔跑吧骚年!让我们红尘做伴 活得潇潇洒洒 策马奔腾共享人世繁华 对酒当歌唱出心中喜悦 轰轰烈烈把握青春年华 让我们红尘做伴 活得潇潇洒洒 策马奔腾共享人世繁华 对酒当歌唱出心中喜悦 轰轰烈烈把握青春年华 啊……啊……啊 两…...

    2024/4/26 23:04:58
  20. 扒开伪装医用面膜,翻六倍价格宰客,小姐姐注意了!

    原标题:扒开伪装医用面膜,翻六倍价格宰客,小姐姐注意了!扒开伪装医用面膜,翻六倍价格宰客!当行业里的某一品项火爆了,就会有很多商家蹭热度,装逼忽悠,最近火爆朋友圈的医用面膜,被沾上了污点,到底怎么回事呢? “比普通面膜安全、效果好!痘痘、痘印、敏感肌都能用…...

    2024/4/25 2:10:52
  21. 「发现」铁皮石斛仙草之神奇功效用于医用面膜

    原标题:「发现」铁皮石斛仙草之神奇功效用于医用面膜丽彦妆铁皮石斛医用面膜|石斛多糖无菌修护补水贴19大优势: 1、铁皮石斛:自唐宋以来,一直被列为皇室贡品,铁皮石斛生于海拔1600米的悬崖峭壁之上,繁殖力差,产量极低,所以古代仅供皇室、贵族享用 2、铁皮石斛自古民间…...

    2024/4/25 18:39:00
  22. 丽彦妆\医用面膜\冷敷贴轻奢医学护肤引导者

    原标题:丽彦妆\医用面膜\冷敷贴轻奢医学护肤引导者【公司简介】 广州华彬企业隶属香港华彬集团有限公司,专注美业21年,其旗下品牌: 「圣茵美」私密荷尔蒙抗衰,产后修复 「圣仪轩」私密荷尔蒙抗衰,产后修复 「花茵莳」私密荷尔蒙抗衰,产后修复 「丽彦妆」专注医学护…...

    2024/4/26 19:46:12
  23. 广州械字号面膜生产厂家OEM/ODM4项须知!

    原标题:广州械字号面膜生产厂家OEM/ODM4项须知!广州械字号面膜生产厂家OEM/ODM流程及注意事项解读: 械字号医用面膜,其实在我国并没有严格的定义,通常我们说的医美面膜指的应该是一种「医用敷料」,也就是说,医用面膜其实算作「医疗器械」的一种,又称「医用冷敷贴」。 …...

    2024/4/25 18:38:58
  24. 械字号医用眼膜缓解用眼过度到底有无作用?

    原标题:械字号医用眼膜缓解用眼过度到底有无作用?医用眼膜/械字号眼膜/医用冷敷眼贴 凝胶层为亲水高分子材料,含70%以上的水分。体表皮肤温度传导到本产品的凝胶层,热量被凝胶内水分子吸收,通过水分的蒸发带走大量的热量,可迅速地降低体表皮肤局部温度,减轻局部皮肤的灼…...

    2024/4/25 18:38:57
  25. 配置失败还原请勿关闭计算机,电脑开机屏幕上面显示,配置失败还原更改 请勿关闭计算机 开不了机 这个问题怎么办...

    解析如下&#xff1a;1、长按电脑电源键直至关机&#xff0c;然后再按一次电源健重启电脑&#xff0c;按F8健进入安全模式2、安全模式下进入Windows系统桌面后&#xff0c;按住“winR”打开运行窗口&#xff0c;输入“services.msc”打开服务设置3、在服务界面&#xff0c;选中…...

    2022/11/19 21:17:18
  26. 错误使用 reshape要执行 RESHAPE,请勿更改元素数目。

    %读入6幅图像&#xff08;每一幅图像的大小是564*564&#xff09; f1 imread(WashingtonDC_Band1_564.tif); subplot(3,2,1),imshow(f1); f2 imread(WashingtonDC_Band2_564.tif); subplot(3,2,2),imshow(f2); f3 imread(WashingtonDC_Band3_564.tif); subplot(3,2,3),imsho…...

    2022/11/19 21:17:16
  27. 配置 已完成 请勿关闭计算机,win7系统关机提示“配置Windows Update已完成30%请勿关闭计算机...

    win7系统关机提示“配置Windows Update已完成30%请勿关闭计算机”问题的解决方法在win7系统关机时如果有升级系统的或者其他需要会直接进入一个 等待界面&#xff0c;在等待界面中我们需要等待操作结束才能关机&#xff0c;虽然这比较麻烦&#xff0c;但是对系统进行配置和升级…...

    2022/11/19 21:17:15
  28. 台式电脑显示配置100%请勿关闭计算机,“准备配置windows 请勿关闭计算机”的解决方法...

    有不少用户在重装Win7系统或更新系统后会遇到“准备配置windows&#xff0c;请勿关闭计算机”的提示&#xff0c;要过很久才能进入系统&#xff0c;有的用户甚至几个小时也无法进入&#xff0c;下面就教大家这个问题的解决方法。第一种方法&#xff1a;我们首先在左下角的“开始…...

    2022/11/19 21:17:14
  29. win7 正在配置 请勿关闭计算机,怎么办Win7开机显示正在配置Windows Update请勿关机...

    置信有很多用户都跟小编一样遇到过这样的问题&#xff0c;电脑时发现开机屏幕显现“正在配置Windows Update&#xff0c;请勿关机”(如下图所示)&#xff0c;而且还需求等大约5分钟才干进入系统。这是怎样回事呢&#xff1f;一切都是正常操作的&#xff0c;为什么开时机呈现“正…...

    2022/11/19 21:17:13
  30. 准备配置windows 请勿关闭计算机 蓝屏,Win7开机总是出现提示“配置Windows请勿关机”...

    Win7系统开机启动时总是出现“配置Windows请勿关机”的提示&#xff0c;没过几秒后电脑自动重启&#xff0c;每次开机都这样无法进入系统&#xff0c;此时碰到这种现象的用户就可以使用以下5种方法解决问题。方法一&#xff1a;开机按下F8&#xff0c;在出现的Windows高级启动选…...

    2022/11/19 21:17:12
  31. 准备windows请勿关闭计算机要多久,windows10系统提示正在准备windows请勿关闭计算机怎么办...

    有不少windows10系统用户反映说碰到这样一个情况&#xff0c;就是电脑提示正在准备windows请勿关闭计算机&#xff0c;碰到这样的问题该怎么解决呢&#xff0c;现在小编就给大家分享一下windows10系统提示正在准备windows请勿关闭计算机的具体第一种方法&#xff1a;1、2、依次…...

    2022/11/19 21:17:11
  32. 配置 已完成 请勿关闭计算机,win7系统关机提示“配置Windows Update已完成30%请勿关闭计算机”的解决方法...

    今天和大家分享一下win7系统重装了Win7旗舰版系统后&#xff0c;每次关机的时候桌面上都会显示一个“配置Windows Update的界面&#xff0c;提示请勿关闭计算机”&#xff0c;每次停留好几分钟才能正常关机&#xff0c;导致什么情况引起的呢&#xff1f;出现配置Windows Update…...

    2022/11/19 21:17:10
  33. 电脑桌面一直是清理请关闭计算机,windows7一直卡在清理 请勿关闭计算机-win7清理请勿关机,win7配置更新35%不动...

    只能是等着&#xff0c;别无他法。说是卡着如果你看硬盘灯应该在读写。如果从 Win 10 无法正常回滚&#xff0c;只能是考虑备份数据后重装系统了。解决来方案一&#xff1a;管理员运行cmd&#xff1a;net stop WuAuServcd %windir%ren SoftwareDistribution SDoldnet start WuA…...

    2022/11/19 21:17:09
  34. 计算机配置更新不起,电脑提示“配置Windows Update请勿关闭计算机”怎么办?

    原标题&#xff1a;电脑提示“配置Windows Update请勿关闭计算机”怎么办&#xff1f;win7系统中在开机与关闭的时候总是显示“配置windows update请勿关闭计算机”相信有不少朋友都曾遇到过一次两次还能忍但经常遇到就叫人感到心烦了遇到这种问题怎么办呢&#xff1f;一般的方…...

    2022/11/19 21:17:08
  35. 计算机正在配置无法关机,关机提示 windows7 正在配置windows 请勿关闭计算机 ,然后等了一晚上也没有关掉。现在电脑无法正常关机...

    关机提示 windows7 正在配置windows 请勿关闭计算机 &#xff0c;然后等了一晚上也没有关掉。现在电脑无法正常关机以下文字资料是由(历史新知网www.lishixinzhi.com)小编为大家搜集整理后发布的内容&#xff0c;让我们赶快一起来看一下吧&#xff01;关机提示 windows7 正在配…...

    2022/11/19 21:17:05
  36. 钉钉提示请勿通过开发者调试模式_钉钉请勿通过开发者调试模式是真的吗好不好用...

    钉钉请勿通过开发者调试模式是真的吗好不好用 更新时间:2020-04-20 22:24:19 浏览次数:729次 区域: 南阳 > 卧龙 列举网提醒您:为保障您的权益,请不要提前支付任何费用! 虚拟位置外设器!!轨迹模拟&虚拟位置外设神器 专业用于:钉钉,外勤365,红圈通,企业微信和…...

    2022/11/19 21:17:05
  37. 配置失败还原请勿关闭计算机怎么办,win7系统出现“配置windows update失败 还原更改 请勿关闭计算机”,长时间没反应,无法进入系统的解决方案...

    前几天班里有位学生电脑(windows 7系统)出问题了&#xff0c;具体表现是开机时一直停留在“配置windows update失败 还原更改 请勿关闭计算机”这个界面&#xff0c;长时间没反应&#xff0c;无法进入系统。这个问题原来帮其他同学也解决过&#xff0c;网上搜了不少资料&#x…...

    2022/11/19 21:17:04
  38. 一个电脑无法关闭计算机你应该怎么办,电脑显示“清理请勿关闭计算机”怎么办?...

    本文为你提供了3个有效解决电脑显示“清理请勿关闭计算机”问题的方法&#xff0c;并在最后教给你1种保护系统安全的好方法&#xff0c;一起来看看&#xff01;电脑出现“清理请勿关闭计算机”在Windows 7(SP1)和Windows Server 2008 R2 SP1中&#xff0c;添加了1个新功能在“磁…...

    2022/11/19 21:17:03
  39. 请勿关闭计算机还原更改要多久,电脑显示:配置windows更新失败,正在还原更改,请勿关闭计算机怎么办...

    许多用户在长期不使用电脑的时候&#xff0c;开启电脑发现电脑显示&#xff1a;配置windows更新失败&#xff0c;正在还原更改&#xff0c;请勿关闭计算机。。.这要怎么办呢&#xff1f;下面小编就带着大家一起看看吧&#xff01;如果能够正常进入系统&#xff0c;建议您暂时移…...

    2022/11/19 21:17:02
  40. 还原更改请勿关闭计算机 要多久,配置windows update失败 还原更改 请勿关闭计算机,电脑开机后一直显示以...

    配置windows update失败 还原更改 请勿关闭计算机&#xff0c;电脑开机后一直显示以以下文字资料是由(历史新知网www.lishixinzhi.com)小编为大家搜集整理后发布的内容&#xff0c;让我们赶快一起来看一下吧&#xff01;配置windows update失败 还原更改 请勿关闭计算机&#x…...

    2022/11/19 21:17:01
  41. 电脑配置中请勿关闭计算机怎么办,准备配置windows请勿关闭计算机一直显示怎么办【图解】...

    不知道大家有没有遇到过这样的一个问题&#xff0c;就是我们的win7系统在关机的时候&#xff0c;总是喜欢显示“准备配置windows&#xff0c;请勿关机”这样的一个页面&#xff0c;没有什么大碍&#xff0c;但是如果一直等着的话就要两个小时甚至更久都关不了机&#xff0c;非常…...

    2022/11/19 21:17:00
  42. 正在准备配置请勿关闭计算机,正在准备配置windows请勿关闭计算机时间长了解决教程...

    当电脑出现正在准备配置windows请勿关闭计算机时&#xff0c;一般是您正对windows进行升级&#xff0c;但是这个要是长时间没有反应&#xff0c;我们不能再傻等下去了。可能是电脑出了别的问题了&#xff0c;来看看教程的说法。正在准备配置windows请勿关闭计算机时间长了方法一…...

    2022/11/19 21:16:59
  43. 配置失败还原请勿关闭计算机,配置Windows Update失败,还原更改请勿关闭计算机...

    我们使用电脑的过程中有时会遇到这种情况&#xff0c;当我们打开电脑之后&#xff0c;发现一直停留在一个界面&#xff1a;“配置Windows Update失败&#xff0c;还原更改请勿关闭计算机”&#xff0c;等了许久还是无法进入系统。如果我们遇到此类问题应该如何解决呢&#xff0…...

    2022/11/19 21:16:58
  44. 如何在iPhone上关闭“请勿打扰”

    Apple’s “Do Not Disturb While Driving” is a potentially lifesaving iPhone feature, but it doesn’t always turn on automatically at the appropriate time. For example, you might be a passenger in a moving car, but your iPhone may think you’re the one dri…...

    2022/11/19 21:16:57