javascript继承

简单的javascript继承:

/* Simple JavaScript Inheritance
 * By John Resig http://ejohn.org/
 * MIT Licensed.
 */
// Inspired by base2 and Prototype
(function(){
  var initializing = false, 
  fnTest = /xyz/.test(function(){xyz;}) ? /\b_super\b/ : /.*/;
 
  // The base Class implementation (does nothing)
  this.Class = function(){};
 
  // Create a new Class that inherits from this class
  Class.extend = function(prop) {
    var _super = this.prototype;
   
    // Instantiate a base class (but only create the instance,
    // don't run the init constructor)
    initializing = true;
    var prototype = new this();
    initializing = false;
   
    // Copy the properties over onto the new prototype
    for (var name in prop) {
      // Check if we're overwriting an existing function
      prototype[name] = typeof prop[name] == "function" &&
        typeof _super[name] == "function" && fnTest.test(prop[name]) ?
        (function(name, fn){
          return function() {
            var tmp = this._super;
           
            // Add a new ._super() method that is the same method
            // but on the super-class
            this._super = _super[name];
           
            // The method only need to be bound temporarily, so we
            // remove it when we're done executing
            var ret = fn.apply(this, arguments);        
            this._super = tmp;
           
            return ret;
          };
        })(name, prop[name]) :
        prop[name];
    }
   
    // The dummy class constructor
    function Class() {
      // All construction is actually done in the init method
      if ( !initializing && this.init )
        this.init.apply(this, arguments);
    }
   
    // Populate our constructed prototype object
    Class.prototype = prototype;
   
    // Enforce the constructor to be what we expect
    Class.prototype.constructor = Class;
 
    // And make this class extendable
    Class.extend = arguments.callee;
   
    return Class;
  };

})();

 

使用继承:

var Person = Class.extend({
  init: function(isDancing){
  this.dancing = isDancing;
  },
  dance: function(){
  return this.dancing;
  }
});

var Ninja = Person.extend({
  init: function(){
    this._super( false );
  },
  dance: function(){
    // Call the inherited version of dance()
    return this._super();
  },
  swingSword: function(){
    return true;
  }
});

 

在html页面里的使用方法:

<html>
<head>
 <script src="./jquery-latest.js"></script>
 <script src="./simple_init.js"></script>
 <script src="./my_extend.js"></script>
</head>
<body> 
 <div id="test" height="100px" width="100px"></div>
</body>
<footer>
</footer>
</html>

<script>
 var n = new Ninja();
 // console.log(n.dance()); // => false
 // n.swingSword(); // => true
</script>

ajax ‘\n\r’ 传递

从数据库传回来的换行符 通过ajax传递到前台好像会出问题,今天早做frasers 的company的时候就遇到了,因为在remarks回车之后会生成换行符 post提交到后台好像也不会转义所以直接存储到了数据库里这样就坑爹了导致后来再post数据回来去做edit的时候ajax页面返回不回来,我现在解决办法可能有些笨 但是目前是可以起到效果。

前端处理:

function replace_br(str){
        return str.replace(/<br \/>/g,"\r\n");
}

新添加:

function str_replace(str){
        var new_str = str.replace(/\"/g,"\\\"");
        new_str = new_str.replace(/\n/g,"<br \/>");
        new_str = new_str.replace(/\r/g,"<br \/>");
        new_str = new_str.replace(/\r\n/g,"<br \/>");
        return new_str;
    }

 

 

后端处理:

function replace_nr($str){
        $new_str = str_replace("\r","<br />",$str);
        $new_str = str_replace("\n","<br />",$new_str);
        $new_str = str_replace("\n\r","<br />",$new_str);
        return $new_str;
}

打印时候页面的style

打印时候页面的style

<style media="print">
.Noprint{display:none;}
.PageNext{page-break-after: always;}
@page {size: 8.3in 11.7in; size: portrait; marks:none; margin: 0.5in;}
@media print {
 p, h4, ul, ol, td, a { font-size: 8pt; }
 h1 { font-size: 9pt; } 
 h2 { font-size: 9pt; } 
 h3 { font-size: 9pt; } 
 h5 { font-size: 9pt; }
}
</style>