监听你系统通信所用的端口,有数据就获取显示就可以了。例如你的服务器ip是16812116,使用的是2000端口号,Socket socket=new Socket("16812116",2000);
DataOutputStream in=new DataOutputStream(socketgetInputStream());
代码如下:
function a(callback){
alert('a');
callbackcall(this);//或者是 callback(), callbackapply(this),看个人喜好
}
function b(){
alert('b');
}
//调用
a(b);
这样的结果是先d出 'a',再d出‘b'。这样估计会有人问了“写这样的代码有什么意思呢?好像没太大的作用呢!”
是的,其实我也觉得这样写没啥意思,“如果调用一个函数就直接在函数里面调用它不就行了”。我这只是给大家写个小例子,做初步的理解。真正写代码的过程中很少用这样无参数的,因为在大部分场景中,我们要传递参数。来个带参数的:
复制代码 代码如下:
function c(callback){
alert('c');
callbackcall(this,'d');
}
//调用
c(function(e){
alert(e);
});
这个调用看起来是不是似曾相识,这里e参数被赋值为'd',我们只是简单的赋值为字符窜,其实也可以赋值为对象。Jquery里面是不是也有个e参数,下面我们就来讲讲
Jquery里面的e参数是如何被回调赋值的。
Jquery框架我想大家不陌生了,出来了好久,开发的时候都在用,比较简单,api网上搜起来很方便,上手快。在Jquery框架下,我们有时候要获取事件中的一些参数,比如我要获取当前点击的坐标,点击的元素对象。这个需求在Jquery里面好办 :
复制代码 代码如下:
$("#id")bind('click',function(e){
//epageX ,epageY ,etarget各种数据
});
用起来倒是挺方便,其实这个e参数的赋值也是通过回调函数来实现的,这个参数是用回调参数给它赋予了一个对象值,仔细研究过JJquery源码的朋友应该发现了这一点。
还有Ajax里面 $get('',{},function(data){}) data这个参数也是同样的原理。
我们来看看Jquery事件对象里面是怎么应用回调函数的。
为了方便,我简单的写了一下$相关的一些实现,之前写过“小谈Jquery”里面有比较接近框架实现的方法,我下面只是写一个简易的选择器。
复制代码 代码如下:
<div id="container" style="width:200px;height:200px;background-Color:green;">
< /div>
< script>
var _$=function (id)
{
thiselement= documentgetElementById(id);
}
_$prototype={
bind:function(evt,callback)
{
var that=this;
if(documentaddEventListener)
{
thiselementaddEventListener(evt, function(e){
callbackcall(this,thatstandadize(e));
} ,false);
}
else if(documentattachEvent)
{
thiselementattachEvent('on'+evt,function(e){
callbackcall(this,thatstandadize(e));
});
}
else
thiselement['on'+evt]=function(e){
callbackcall(this,thatstandadize(e));
};
},
standadize:function(e){
var evt=e||windowevent;
var pageX,pageY,layerX,layerY;
//pageX 横坐标 pageY纵坐标 layerX点击处位于元素的横坐标 layerY点击处位于元素的纵坐标
if(evtpageX)
{
pageX=evtpageX;
pageY=evtpageY;
}
else
{
pageX=documentbodyscrollLeft+evtclientX-documentbodyclientLeft;
pageY=documentbodyscrollTop+evtclientY-documentbodyclientLTop;
}
if(evtlayerX)
{
layerX=evtlayerX;
layerY=evtlayerY;
}
else
{
layerX=evtoffsetX;
layerXY=evtoffsetY;
}
return {
pageX:pageX,
pageY:pageY,
layerX:layerX,
layerY:layerY
}
}
}
window$=function(id)
{
return new _$(id);
}
$('container')bind('click',function(e){
alert(epageX);
});
$('container1')bind('click',function(e){
alert(epageX);
});
< /script>
这段代码我们主要看standadize函数的实现,兼容性的代码,就不多说了,返回的是一个对象
复制代码 代码如下:
return {
pageX:pageX,
pageY:pageY,
layerX:layerX,
layerY:layerY
}
然后再看bind函数里面的代码 callbackcall(this,thatstandadize(e)),这段代码其实就是给e参数赋值了,是用callback回调实现的。
callback 函数被调用的时候传入的是匿名函数
复制代码 代码如下:
function(e){
}
而callbackcall(this,thatstandadize(e))相当于是执行了这么一段代码
复制代码 代码如下:
(function(e){
})(standadize(e))
这也是Jquery用回调函数比较经典的地方,e参数就是这么被赋值的,说了这些你们也大概有个了解了,以及怎么使用了。
回调在各种框架中应用的比较多,有时候自己写一些东西的时候也可以根据实际情况用用看。
简单版,拷贝运行
================================
<html>
<head>
<meta >
首先写获取值的js方法\x0d\displayUpload('uploadDiv3'){\x0d\ // 给相关action传值\x0d\ windowlocation='接收的参数=uploadDiv3;\x0d\}\x0d\在action中有接受的属性\x0d\可使用\x0d\String uploadDiv3 = requestgetP("uploadDiv3"); \x0d\其次\x0d\在jsp页面上\x0d\onclick="JavaScript:displayUpload(传入的值);" \x0d\\x0d\补充回答:\x0d\你想要在哪里判断?\x0d\是在jsp页面上\x0d\还是java程序中\x0d\如果是jsp页面上的话,可以\x0d\function displayUpload(uploadDiv3){\x0d\ if(uploadDiv3==是否等于你的条件){\x0d\ // 如果等于则\x0d\ }else{\x0d\ // 不等于则\x0d\ }\x0d\}
本章内容分为三部分:
开始之前先简单了解一下
如:url地址: >
示例:
URL: >
通过request的getParameter的方法获取。
通过requestgetParameter("参数名")获取后台的值通过的方式赋给js变量示例。
给你提供一个通用的函数
var getSearch = function( url , name ){if( !name ){
name = url;
url = locationhref;
}
var rv = '';
url = urlindexOf('') > -1 urlsplit('')[1] : '';
if(url != ''){
var ls = urlsplit('&');
for(var i=0;i<lslength;i++){
var ele = ls[i];
var kname = elesplit('=')[0] ||'',kvalue = elesplit('=')[1] || '';
if(kname === name){
rv = kvalue;
break;
}
}
}
return decodeURIComponent(rv);
}
//调用的时候就可以通过getSearch直接获得
//比如获得url中的name
function f1(){
var name = getSearch('name');
documentgetElementById("d1")value=name;
}
以上就是关于js发送请求的时候想要获取请求的地址及参数全部的内容,包括:js发送请求的时候想要获取请求的地址及参数、js怎样获取调用回调函数的参数值、js如何获取链接地址的参数值等相关内容解答,如果想了解更多相关内容,可以关注我们,你们的支持是我们更新的动力!
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)