往事不堪回首,折腾了个把月的老系统,心中郁结,不吐不快。系统架构是ASP +VBS +VB6.0 + SQL Server2000, 第一个版本开发完成大概是在2000年。基本是处于交接无力,看代码就如同走迷宫的节奏。不过我觉得第一批开发人员应该可以自傲了,它们做的系统这么多年过去了居然还活着。

为了对得起这几天死掉的脑细胞,就权且在这里留下它们阵亡的痕迹。

变量的声明

VB6.0:

Dim x as integer

VBS:

Dim x

同样的功能,由于代码太过Dirty,有部分模块写在了ASP 的VBS中,有部分模块写在了COM 组件的VB6.0 中。某日直接拷贝VB6.0 的代码修改到VBS, 始终无法运行成功。

用>1 hour 脑细胞的代价,发现是声明变量的时候不能照拷,不能声明变量的类型,或者干脆直接抹掉不写声明直接用即可。

变量的赋值

今天要给Session 赋值。

VBS:

工作正常的代码

set session("record") = record;

悲剧的代码

set session("userId") = 50

两个同样的语句,第一句能够正常运行,第二句居然不行。

正确的使用方式:

set session("record") = record;

session("age") = 50

用> 2 hour 脑细胞的代价,发现set 方式用来赋值对象,如果直接是数值,字符串之类的东西不能用set,而用let, 当然可以省略!

VBS 基础

虽然说脑细胞死了不少,这里还是希望找个坑将VBS 的基础知识埋了。VB6.0 的功能和VBS 类似,但是如果同时学同时都不精悲剧的概率极大,故这里就只讲VBS.

VBScript 历史

全名Visual Basic Scripting Editon

从桌面系统的Windows98,服务版的Windows NT4.0 开始微软家就自带支持VBS了。

在浏览器端,功能和Java Script 类似,显然除了IE其他浏览器都不买账,被干趴下了。

在系统管理员端,微软自家都建议用Windows PowerShell,况且原来也可以用BAT.

在服务器端,ASP + VBS的结构看上去就吓坏不少小盆友, 不过这种公司还活着几个。

估计就QTP + Excel 里面用用还是不错的。(既然评论里面有人说起了vba,为了防止误解,这里暂时抹掉Excel )

但是: 查看某语言的月度排行,VB6.0 可是只比C# 低一点点的存在,高的一塌糊涂。这段和VBS 无关,不该放这里

套用网上流行的段子:VB VBA VBS

VB和VBA本就是同宗的姐妹,只不过姐姐VB的功夫要比妹妹VBA历害些。不过姐姐只会单打独斗是女强人;妹妹却只会傍大款。姐姐有生育能力,是真正的女人;妹妹却不会生崽,但深谱相夫之道,一番教导指挥之下可使她老公增色不少,而VBS呢,也是大户人家的女儿,不过没有VB和VBA姐妹优秀的血统,娇小玲珑干不得粗活只能指挥些自动听话的对象来干活,她乐于助人品德好不象VBA那样只认大款,VB、VBAvbs三个女人我都喜欢。

VBS 语言特性

VBS 是以Visual Basic 为模型。因此有类似的过程,结构,常量,变量,时间日期,异常处理,正则表达式等。。。。。。

Procedure :

Function

Subroutine

参数传递:

传值

传引用

无数内置的常量:

Color Constants   
Comparison Constants   
Date and Time Constants   
Date Format Constants   
Miscellaneous Constants   
MsgBox Constants   
String Constants   
Tristate Constants   
VarType Constants 

变量类型:

不用显式Dim 变量类型,默认基础类型都是Variant

当然如果不指定Option Explicit, 变量可以不声明直接用。

无数内置的方法:

。。。。。。。。。。

CDate

CDbl

Chr

CInt

CLng

Conversions

Cos

CreateObject

CSng

CStr

Date

各种关键字

Empty : uninitialized

False  :0

Nothing :对象没有指向东西

Null : 变量没有包含有效数据

True : –1

各种入门级别的小代码块

这里的小代码都整理和来自于网络,windows 平台的随便记事本保存下即可运行。

弹出Hello World:

msgbox true=-1
msgbox true=1
MsgBox "Hello World!"

更复杂的弹出窗口

' These three produce the same result. However, the use of constants as in the third line
' is considered best practice.
x = MsgBox("Hello World:Text",1+64+4096,"Hello World:Title")
x = MsgBox("Hello World:Text",4161,"Hello World:Title")
x = MsgBox("Hello World:Text", vbOKCancel+vbInformation+vbSystemModal, _
           "Hello World:Title")

' Presents the number corresponding to the button pressed. Different constants will produce
' different behaviours. For example, vbOKCancel specifies two buttons in the dialogue box,
' whereas vbYesNoCancel specifies three.
x = MsgBox("Hello World:Text", vbYesNoCancel+vbInformation,"Hello World:Title")
MsgBox "The result is " & x

调用WMI 关闭记事本

Option Explicit
Dim strComputer, strProcessToKill, objWMIService, colProcess, objProcess

strComputer = "."
strProcessToKill = "notepad.exe"
Set objWMIService = GetObject("winmgmts:" _
   & "{impersonationLevel=impersonate}!\\" _
   & strComputer _
   & "\root\cimv2")
Set colProcess = objWMIService.ExecQuery _
   ("Select * from Win32_Process Where Name = '" & strProcessToKill & "'")
For Each objProcess in colProcess
   MsgBox "... terminating " & objProcess.Name
   objProcess.Terminate()
Next

创建文件

For i = 1 to 10
createFile( i )
Next

Public sub createFile(a)
Dim fso,myFile
filePath = "C:\file_name" & a & ".txt"
Set fso=CreateObject("Scripting.FileSystemObject")
Set MyFile= fso.CreateTextFile( filePath)
MyFile.WriteLine("This is a separate file")
msgbox 1111
'MyFile.close
stop
end sub

这个可以改成Merry Christmas,不过估计无知小妹妹会觉得你很无聊。

Dim WshShell
Set WshShell=WScript.CreateObject("WScript.Shell")
WshShell.Run"notepad"
WScript.Sleep 1500
WshShell.AppActivate"Untitled-Notepad"
WshShell.SendKeys"H"
WScript.Sleep 500
WshShell.SendKeys"a"
WScript.Sleep 500
WshShell.SendKeys"p"
WScript.Sleep 500
WshShell.SendKeys"p"
WScript.Sleep 500
WshShell.SendKeys"y"
WScript.Sleep 500
WshShell.SendKeys""
WScript.Sleep 500
WshShell.SendKeys"B"
WScript.Sleep 500
WshShell.SendKeys"i"
WScript.Sleep 500
WshShell.SendKeys"r"
WScript.Sleep 500
WshShell.SendKeys"t"
WScript.Sleep 500
WshShell.SendKeys"h"
WScript.Sleep 500
WshShell.SendKeys"d"
WScript.Sleep 500
WshShell.SendKeys"a"
WScript.Sleep 500
WshShell.SendKeys"y"
WScript.Sleep 500
WshShell.SendKeys"!"
WScript.Sleep 500
WshShell.SendKeys"%FS"
WScript.Sleep 500
WshShell.SendKeys"b"
WScript.Sleep 500
WshShell.SendKeys"i"
WScript.Sleep 500
WshShell.SendKeys"r"
WScript.Sleep 500
WshShell.SendKeys"t"
WScript.Sleep 500
WshShell.SendKeys"h"
WScript.Sleep 500
WshShell.SendKeys"%S"
WScript.Sleep 500
WshShell.SendKeys"%FX" 

生成一个GUID, 不用打开baidu了。

Set TypeLib = CreateObject("Scriptlet.TypeLib")
strGUID = Left(TypeLib.Guid,38)
myfilename = "C:\guid.txt"
MakeHelloWorldFile myfilename strGUID

Sub MakeHelloWorldFile (FileName,guid)
'Create a new file in C: drive or overwrite existing file
   Set FSO = CreateObject("Scripting.FileSystemObject")
   Set FileObject = FSO.CreateTextFile (FileName)
   FileObject.WriteLine 

   FileObject.Close()
End Sub

当然可以直接用VBS 执行数据库脚本,不用打开SQL Management了。

.........省略

写在最后

这个古董项目看来是没完没了了,于是我果断裸辞滚蛋了,希望这辈子都不要再碰什么VB6.0, 什么ASP了,也希望接手的人一路走好。

C# 还有 Java, 哥又满血复活回来了,想哥了没?

吐个槽,对VB6.0 还有VBS 说ByeBye的更多相关文章

  1. VB6.0中,DTPicker日期、时间控件不允许为空时,采用文本框与日期、时间控件相互替换赋值(解决方案)

    VB6.0中,日期.时间控件不允许为空时,采用文本框与日期.时间控件相互替换赋值,或许是一个不错的选择. 实现效果如下图: 文本框txtStopTime1 时间框DTStopTime1(DTPicke ...

  2. VB6.0 和VB.NET 函数对比

    VB6.0和VB.Net的对照表 VB6.0 VB.NET AddItem Object名.AddItem Object名.Items.Add ListBox1.Items.Add ComboBox1 ...

  3. VB6.0 调用存储过程

    最近有在做一个需求,需要在VB6.0中调用存储过程,整理了一下,供大家参考, 范例: Function callStoredProcedure(sEmployeeID As String, Optio ...

  4. VB6.0和VB.Net的函数等对照表

    VB6.0和VB.Net的对照表 VB6.0 VB.NET AddItem Object名.AddItem Object名.Items.Add ListBox1.Items.Add ComboBox1 ...

  5. 【原创】VB6.0应用程序安装包的生成(Setup Factory 9.0制作安装包的方法)

    VB6.0应用程序安装包的生成,利用其自带的打包工具生成的安装程序很简陋,一点不美观:如果想让自己的应用程序安装的时候显得高大上一点,本教程提供使用Setup Factory 9.0制作安装包的方法. ...

  6. vb6.0安装程序制作图解教程

    如何制作vb安装程序,是在学习Vb6.0过程中比较常见的一个入门问题. 在此笔者介绍一个最简单的安装方法,就是用VB自带的打包程序进行打包,虽然比较普通,不过内部却有不少窍门,相信这一点知道的人可能不 ...

  7. VB6.0

    1. 安装包来自 http://msdn.itellyou.cn/ 下载的文件为: sc_vb6_ent_cd1.iso sc_vb6_ent_cd2.iso 2.安装时,"请输入产品的 I ...

  8. VB6.0调用DLL

    目录 第1章 VB6.0调用DLL    1 1 VC++编写DLL    1 1.1 使用__stdcall    1 1.2 使用 .DEF 文件    1 2 简单数据类型    2 2.1 传 ...

  9. VB6.0编程笔记——(2)开发环境准备&学习前导入

    工欲善其事必先利其器,着手开始学习写代码之前,我们需要先准备好需要用到的工具.这篇文章会教大家部署好环境,同时会告知前期我们需要知道的一点内容(可以不用特别理解,只要记住用法就行,后续会深入展开介绍) ...

随机推荐

  1. django rest framework 的url标签的问题

    如何在模板中引用一个在rest framework中的url? urls.py from django.conf.urls import patterns, url from .views impor ...

  2. Ajax基础2

    什么是服务器 网页浏览过程的分析 如何配置自己的服务器程序(AMP) 什么是Ajax 无刷新数据读取 异步,同步 Ajax基础(2) 使用Ajax 基础请求显示txt的文件 字符集编码 缓存,阻止缓存 ...

  3. Python正则表达式汇总

    判断是否是整数或小数,在网上看到一个方法: type(eval(")) == int type(eval("123.23")) == float 后来又看到<Pyt ...

  4. malloc/free与new/delete的区别

    相同点:都可用于申请动态内存和释放内存 不同点:(1)操作对象有所不同.malloc与free是C++/C 语言的标准库函数,new/delete 是C++的运算符.对于非内部数据类的对象而言,光用m ...

  5. Unity3d《Shader篇》Logo闪光特效

    Shader "Custom/Flash" { Properties { _MainTex ("Base (RGB)", 2D) = "white&q ...

  6. [ 转]Collections.unmodifiableList方法的使用与场景

    在公司接触到Collections.unmodifiableList(List<? extends T> list)) 觉得用法挺特殊的,所以学习了下,简单而言,看名字就知道,将参数中的L ...

  7. 1.openstack之mitaka搭建基本配置

    介绍:本次案列为基本的三节点部署 注:搭建所需要的包可以联系QQ:22102107获取 一:网络: 1.管理网络:192.168.11.0/24 2.数据网络:1.1.1.0/24 注:每个节点两个网 ...

  8. Python: 程序print到文件中

    Python 3.x 将输出内容写入到一个文件,需要两个命令.open指明Python用什么文件名,w 意味着我们要写入该文件, encoding=”utf-8″指明Python如何把中文写入该文件. ...

  9. Android Multimedia框架总结(二)MediaPlayer框架及播放网络视频案例

    前言:前面一篇我们介绍MediaPlayer相关方法,有人说,没有实际例子,看得不是很明白,今天在分析MediaPlayer时,顺带一个播放网络视频例子.可以自行试试.今天分析的都是下几篇介绍各个模块 ...

  10. SQL Server 子查询

    这些主要是老师上课讲的一些知识点,自己做了一些整理放在这里~~~ 子查询可以是标量的.多值的或是表值的. 在期待单个值的地方可以使用标量子查询.例如,以下查询返回具有最大员工编号的员工信息: SELE ...