往事不堪回首,折腾了个把月的老系统,心中郁结,不吐不快。系统架构是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. powerdesigner反向

    1.Could not initial JVM不能初始化 :要求安装32位的JDK,把path指向32的安装目录 2.Non SQL Error : Could not load class orac ...

  2. mysql同一台服务器上不同数据库中个别表内容同步

    >>>>>>soft_wsx>>>>>>--数据备份与还原>>同步备用服务器--1.完全备份主数据库--2.使用带S ...

  3. [k]css盒模型

    box-sizing :  content-box || border-box || inherit 1.content-box:此值为其默认值.元素的宽度/高度(width/height)等于元素边 ...

  4. 解决Django发送中文邮件时的编码及乱码问题

    参考自---http://blog.csdn.net/clh604/article/details/9274793 #-*- coding=utf8 -*- from email.message im ...

  5. c3p0 config

    c3p0-config.xml<?xml version="1.0" encoding="UTF-8"?> <c3p0-config> ...

  6. Appium+Robotframework实现Android应用的自动化测试-7:模拟器频繁挂掉的解决方案

    如果测试用例比较多,则当持续运行多个测试用例后,经常会出现模拟器崩溃或者Appium无法连接到该模拟器的情况出现. 经过分析,本人认为这应该是模拟器或者Appium的缺陷造成的,目前并没有直接的解决方 ...

  7. 关于TxQBService报的错,腾讯你真牛B啊

    腾讯你真牛B啊,浏览器都7了,还特么的报这么低级的错误,还每10秒写一条windows日志,让人有什么心情用你的浏览器,滚.

  8. 【Android Studio错误】 If you are behind an HTTP proxy, please configure the proxy settings either in IDE or Gradle.

    解决办法:以管理员身份运行cmd窗口,输入命令“netsh winsock reset” netsh winsock reset命令,作用是重置 Winsock 目录.如果一台机器上的Winsock协 ...

  9. Binary String Matching

    问题 B: Binary String Matching 时间限制: 3 Sec  内存限制: 128 MB提交: 4  解决: 2[提交][状态][讨论版] 题目描述 Given two strin ...

  10. codeforces 495B. Modular Equations 解题报告

    题目链接:http://codeforces.com/problemset/problem/495/B 题目意思:给出两个非负整数a,b,求出符合这个等式      的所有x,并输出 x 的数量,如果 ...