Javascript與vbscript數(shù)據(jù)共享
更新時間:2007年01月09日 00:00:00 作者:
如有紕漏之處,請指出,謝謝
1、普通全局變量
在browser里,引用一個全局變量,可以有很多方法,你可以直接引用該變量,也可以用window.variable來引用全局變量,原因是因為全局變量屬于window的窗體,但是當(dāng)每新開一個窗口,瀏覽器會自動清空先前已有變量(也就是說,每個新開頁面都是一個“有清白之身的web頁”,因此在新開的窗口里是不可以引用之前定義的變量,如果要引用,可以變向獲取,如通過URL的參數(shù)傳遞等方法來獲取,但這是后話了)如:
<script>
var global = "this is a global var."
</script>
<SCRIPT LANGUAGE="vbScript">
<!--
alert(window.global)
alert(global)
//-->
</SCRIPT>
輸出結(jié)果:
this is a global var.
this is a global var.
2、vbs引用js的對象(非原型prototype對象)、函數(shù)
可直接引用:即對象名.屬性名
<SCRIPT LANGUAGE="JavaScript">
<!--
function obj(){};
obj.string="test";
obj.replacec=function(s){return s.replace(/c/,"")};
//-->
</SCRIPT>
<SCRIPT LANGUAGE="vbScript">
<!--
alert(obj.string)
obj.string="change"
alert(obj.string)
alert(obj.replacec(obj.string))
//-->
</SCRIPT>
輸出結(jié)果:
change
hange
當(dāng)js是prototype型時,vbs可以用以下方法來訪問js的成員
<SCRIPT LANGUAGE="JavaScript">
<!--
function myClass(s)
{
this.s=s
return this;
};
myClass.prototype.output=function()
{
alert(this.s);
}
var obj=new myClass("blueDestiny");
//-->
</SCRIPT>
<SCRIPT LANGUAGE="vbScript">
<!--
obj.output()
//-->
</SCRIPT>
3、js里調(diào)用vbs里的class,可先在vbs里先生成一個實例,js可以通過這個實例來訪問vbs的成員。
<SCRIPT LANGUAGE="vbScript">
<!--
class myClass
public s
public sub alertstring()
alert(s)
end sub
end class
set obj=new myClass
//-->
</SCRIPT>
<SCRIPT LANGUAGE="JavaScript">
<!--
obj.s="blueDestiny"
obj.alertstring()
//-->
</SCRIPT>
輸出結(jié)果:
blueDestiny
4、js調(diào)用vbs定義的數(shù)組問題,可直接得用下標(biāo)來獲得第幾個元素的值。
<SCRIPT LANGUAGE="vbScript">
dim a(2)
a(0)="blue"
a(1)="destiny"
</script>
<script>
<!--
alert(a(0))
alert(a(1))
//-->
</SCRIPT>
輸出結(jié)果:
blue
destiny
但是,如何將vbs的數(shù)組轉(zhuǎn)換成js的數(shù)組呢?可以利用js的VBArray()對象,以及toArray()方法,值得注意的是,toArray()方法得出的是一個一維數(shù)組:
<SCRIPT LANGUAGE="VBScript">
<!--
Function CreateVBArray()
Dim i, j, k
Dim a(2, 2)
'初始化二維數(shù)組
k = 1
For i = 0 To 2
For j = 0 To 2
a(j, i) = k
document.writeln(k)
k = k + 1
Next
document.writeln("<BR>")
Next
CreateVBArray = a
End Function
-->
</SCRIPT>
<SCRIPT LANGUAGE="JScript">
<!--
function VBArrayTest(vbarray)
{
//調(diào)用VBArray()對象,將vbs數(shù)組轉(zhuǎn)化為js的數(shù)組并調(diào)用toArray()方法得到一維數(shù)組。
var a = new VBArray(vbarray);
var b = a.toArray();
var i;
for (i = 0; i < 9; i++)
{
document.writeln(b[i]);
}
}
VBArrayTest(CreateVBArray());
-->
</SCRIPT>
輸出結(jié)果:
1 2 3
4 5 6
7 8 9
1 2 3 4 5 6 7 8 9
5、js數(shù)組轉(zhuǎn)化為vbs數(shù)組:
得到j(luò)s的數(shù)組長度,可直接用length屬性獲得
<SCRIPT LANGUAGE="JavaScript">
<!--
var arr=["blue","Destiny"];
//-->
</SCRIPT>
<SCRIPT LANGUAGE="vbScript">
<!--
alert(arr.length)
//-->
</SCRIPT>
輸出結(jié)果:
2
如果要通過下標(biāo)訪問js的數(shù)組元素,將無法獲取,但可通過現(xiàn)有的方法:join()(js里的方法)以及Split()
<SCRIPT LANGUAGE="vbScript">
<!--
'注:這里不可用vbs的join(arr,",")方法,實際上這里所用到的是js里的join方法,并且為vbs的
vbarr=arr.join(",")
vbarr=split(vbarr,",")
alert(vbarr(0))
alert(vbarr(1))
//-->
</SCRIPT>
輸出結(jié)果
blue
Destiny
1、普通全局變量
在browser里,引用一個全局變量,可以有很多方法,你可以直接引用該變量,也可以用window.variable來引用全局變量,原因是因為全局變量屬于window的窗體,但是當(dāng)每新開一個窗口,瀏覽器會自動清空先前已有變量(也就是說,每個新開頁面都是一個“有清白之身的web頁”,因此在新開的窗口里是不可以引用之前定義的變量,如果要引用,可以變向獲取,如通過URL的參數(shù)傳遞等方法來獲取,但這是后話了)如:
<script>
var global = "this is a global var."
</script>
<SCRIPT LANGUAGE="vbScript">
<!--
alert(window.global)
alert(global)
//-->
</SCRIPT>
輸出結(jié)果:
this is a global var.
this is a global var.
2、vbs引用js的對象(非原型prototype對象)、函數(shù)
可直接引用:即對象名.屬性名
<SCRIPT LANGUAGE="JavaScript">
<!--
function obj(){};
obj.string="test";
obj.replacec=function(s){return s.replace(/c/,"")};
//-->
</SCRIPT>
<SCRIPT LANGUAGE="vbScript">
<!--
alert(obj.string)
obj.string="change"
alert(obj.string)
alert(obj.replacec(obj.string))
//-->
</SCRIPT>
輸出結(jié)果:
change
hange
當(dāng)js是prototype型時,vbs可以用以下方法來訪問js的成員
<SCRIPT LANGUAGE="JavaScript">
<!--
function myClass(s)
{
this.s=s
return this;
};
myClass.prototype.output=function()
{
alert(this.s);
}
var obj=new myClass("blueDestiny");
//-->
</SCRIPT>
<SCRIPT LANGUAGE="vbScript">
<!--
obj.output()
//-->
</SCRIPT>
3、js里調(diào)用vbs里的class,可先在vbs里先生成一個實例,js可以通過這個實例來訪問vbs的成員。
<SCRIPT LANGUAGE="vbScript">
<!--
class myClass
public s
public sub alertstring()
alert(s)
end sub
end class
set obj=new myClass
//-->
</SCRIPT>
<SCRIPT LANGUAGE="JavaScript">
<!--
obj.s="blueDestiny"
obj.alertstring()
//-->
</SCRIPT>
輸出結(jié)果:
blueDestiny
4、js調(diào)用vbs定義的數(shù)組問題,可直接得用下標(biāo)來獲得第幾個元素的值。
<SCRIPT LANGUAGE="vbScript">
dim a(2)
a(0)="blue"
a(1)="destiny"
</script>
<script>
<!--
alert(a(0))
alert(a(1))
//-->
</SCRIPT>
輸出結(jié)果:
blue
destiny
但是,如何將vbs的數(shù)組轉(zhuǎn)換成js的數(shù)組呢?可以利用js的VBArray()對象,以及toArray()方法,值得注意的是,toArray()方法得出的是一個一維數(shù)組:
<SCRIPT LANGUAGE="VBScript">
<!--
Function CreateVBArray()
Dim i, j, k
Dim a(2, 2)
'初始化二維數(shù)組
k = 1
For i = 0 To 2
For j = 0 To 2
a(j, i) = k
document.writeln(k)
k = k + 1
Next
document.writeln("<BR>")
Next
CreateVBArray = a
End Function
-->
</SCRIPT>
<SCRIPT LANGUAGE="JScript">
<!--
function VBArrayTest(vbarray)
{
//調(diào)用VBArray()對象,將vbs數(shù)組轉(zhuǎn)化為js的數(shù)組并調(diào)用toArray()方法得到一維數(shù)組。
var a = new VBArray(vbarray);
var b = a.toArray();
var i;
for (i = 0; i < 9; i++)
{
document.writeln(b[i]);
}
}
VBArrayTest(CreateVBArray());
-->
</SCRIPT>
輸出結(jié)果:
1 2 3
4 5 6
7 8 9
1 2 3 4 5 6 7 8 9
5、js數(shù)組轉(zhuǎn)化為vbs數(shù)組:
得到j(luò)s的數(shù)組長度,可直接用length屬性獲得
<SCRIPT LANGUAGE="JavaScript">
<!--
var arr=["blue","Destiny"];
//-->
</SCRIPT>
<SCRIPT LANGUAGE="vbScript">
<!--
alert(arr.length)
//-->
</SCRIPT>
輸出結(jié)果:
2
如果要通過下標(biāo)訪問js的數(shù)組元素,將無法獲取,但可通過現(xiàn)有的方法:join()(js里的方法)以及Split()
<SCRIPT LANGUAGE="vbScript">
<!--
'注:這里不可用vbs的join(arr,",")方法,實際上這里所用到的是js里的join方法,并且為vbs的
vbarr=arr.join(",")
vbarr=split(vbarr,",")
alert(vbarr(0))
alert(vbarr(1))
//-->
</SCRIPT>
輸出結(jié)果
blue
Destiny
相關(guān)文章
原生Js與jquery的多組處理, 僅展開一個區(qū)塊的折疊效果
同一個頁面, 有多組(不固定), 每組區(qū)塊數(shù)量不一定一樣的小區(qū)塊. 要求每次只展開一個區(qū)塊,需要的朋友可以參考下。2011-01-01不用AJAX和IFRAME,說說真正意義上的ASP+JS無刷新技術(shù)
注明:以下方法都經(jīng)過實例和開發(fā)的長期驗證,其實這些技術(shù)早就有,今天只不過自己歸納一下2008-09-09ES6 Iterator遍歷器原理,應(yīng)用場景及相關(guān)常用知識拓展詳解
這篇文章主要介紹了ES6 Iterator遍歷器原理,應(yīng)用場景及相關(guān)常用知識拓展,結(jié)合實例形式詳細(xì)分析了ES6 Iterator遍歷器具體原理、功能、用法、應(yīng)用場景及知識拓展,需要的朋友可以參考下2020-02-02