根据网上公布的全国省市县代码我们可以发现获取省,市,县有以下规律。1:获取省份:select BH,MC from DIC_Area where BH like '__0000' order by BH 获取省份的规律为:前两位数不同后面四位是都为02.获取市:select BH,MC from dic_area where BH like SUBSTRING(BH,1,2)+'__00' and BH <> SUBSTRING(BH,1,2)+'0000' order by BH //sql 取法select BH, MC from Read More
posted @ 2012-10-08 09:33 用未来思考现在 阅读(4018) 评论(15) 推荐(1) Edit
从去年开始用Oracle(注:本人使用的是9i)后很久没有用SQLSERVER2008写SQL了,昨天打开SQLSERVER2008编辑器,不由想起了曾经教我怎么写出性能更高的SQL和教我写第一个Jquery插件的兄弟,在此由衷的感谢:“Ben(小强)”(没有他也许我现在还是超级菜鸟,现在他还是很年轻的构架师哦),第二个要感谢的人是”万哥”(第一个教我写Jquery插件,小强就是万哥培养出来的哦,元老级,呵呵)。为了在使用Oracle的同时,不让自己SQLSERVER退步,虽然Oracle和SQLSERVER语句大部份语句有相同之处,当使用Oracle后发现SQLSERVER有些特性比Orac Read More
posted @ 2012-06-21 15:23 用未来思考现在 阅读(2292) 评论(18) 推荐(5) Edit

ECMAScript中最有意思,最强大的地方在于函数。最进在完善自己的js类库的时候发现我们经常在用函数,但真的很少有人懂得ECMAScript函数功能。

1:什么是函数?

  ECMAScript函数其实就是对象,每个函数都是Function类型的实例而且有属性和方法,由于函数是对象,函数名其实就是指向函数对象的指针,不会与某个函数绑定。

2:创建函数的方法

(1):function Person(name)
   {
    return name;
   }
(2):var Person=function(name)
  {
  return name;
  }

(3):var Person=new function(“name”,”return name”);(不推荐使用,ECMAScript会解析两次所以不推荐使用)

 

3:函数声明和函数表达式的不同

  ECMAScript对函数声明和函数表达式的解析并非一视同仁,解析器会先读取函数声明,并使其在任何代码前都可用。

  例:

assert(false);
 function assert(value, msg) {
 if (!value) {
       alert (msg || (value + " does not equal true"));
            }
     }

函数表达式为执行到这一行才解析器才会解析

如:assert(false);
      var assert=  function (value, msg) {
            if (!value) {
                alert (msg || (value + " does not equal true"));
            }

        }

4:理解this属性

 this 属性是我们经常用的属性,其行为与Java,C#,PHP大致类似。

如:window.name=’用未来思考现在’;

window.name = "用未思考现在;
        showName();
        function showName() {
            alert(this.name);
        }

5:创建自己的类库插件

简单的介绍了下函数,对于理解函数这些内容远远不够,例如构造函数模式,原形模式,原形链等等都是要花很多时间去理解。

创建类

var Class = function () {
    var extclass = function () {
       //接收属性传过来的参数
        this.init.apply(this, arguments);
    }
    //给类添加自定义属性
    extclass.prototype.init = function () { };
    //给prototypr定义别名?
    extclass.fn = extclass.prototype;
    //定义类的别名?
    extclass.fn.parent = extclass;
    //给类添加属性
    extclass.extend = function (obj) {
        var extended = obj.extended;
        for (var i in obj) {
            extclass.fn[i] = obj[i];
        }
        if (extended) extended(extclass);
    };

    //给实例添加属性
    extclass.include = function (obj) {
        var included = obj.included;
        for (var i in obj) {
            extclass.fn[i] = obj[i];
        }
        if (included) included(extclass);
    }
    return extclass;

}

类库大致的框架构建完成,这样我们创建类可以调用extended方法,创建实例可以调用include方法。下一章节会在此基础上扩展更多功能,基于原型给“类”添加继承。

posted @ 2012-11-22 09:24 用未来思考现在 阅读(1384) 评论(5) 推荐(2) Edit
点击右上角即可分享
微信分享提示