当前位置:千赢国际官网 > 千赢网页手机版登入 > JavaScript之AOP编程实例,jquery获得当前html页面源码

JavaScript之AOP编程实例,jquery获得当前html页面源码

文章作者:千赢网页手机版登入 上传时间:2019-07-17

本文实例讲述了jquery获得当前html页面源码的方法。分享给大家供大家参考。具体实现方法如下:

本文实例讲述了JavaScript之AOP编程。分享给大家供大家参考。具体如下:

1.jquery.extend(object); 为扩展jQuery类本身.为类添加新的方法。
jquery.fn.extend(object);给jQuery对象添加方法。

$("#btnGetCode").click(function(){
  var a = '<!DOCTYPE html><html lang="zh-cn">';
  var z = "</html>"
  var by = $(":root").html();
  $("#codeView").val(a by z);
});
/*
// aop({options});
// By: adamchow2326@yahoo.com.au
// Version: 1.0
// Simple aspect oriented programming module
// support Aspect before, after and around
// usage:
    aop({
      context: myObject,   // scope context of the target function.
      target: "test",     // target function name
      before: function() {  // before function will be run before the target function
        console.log("aop before");
      },
      after: function() {   // after function will be run after the target function
        console.log("aop after");
      },
      around: function() {  // around function will be run before and after the target function
        console.log("aop around");
      }
    });
*/
var aop = (function() {
  var options = {},
    context = window,
    oFn,
    oFnArg,
    targetFn,
    targetFnSelector,
    beforeFn,
    afterFn,
    aroundFn,
    cloneFn = function(Fn) {
      if (typeof Fn === "function") {
        return eval('['  Fn.toString()  ']')[0];
      }
      return null;
    },
    checkContext = function() {
      if (options.context) {
        context = options.context;
      }
      if (typeof context[(options.target).name] === "function") {
        targetFnSelector = (options.target).name;
        targetFn = context[targetFnSelector];
      }
      else if (typeof context[options.target] === "function") {
        targetFnSelector = options.target;
        targetFn = context[targetFnSelector];
      }
      if (targetFn) {
        oFn = cloneFn(targetFn);
        oFnArg = new Array(targetFn.length);
        return true;
      }
      else {
        return false;
      }
    },
    run = function() {
      context[targetFnSelector] = function(oFnArg) {
        if (aroundFn){
          aroundFn.apply(this, arguments);
        }
        if (beforeFn){
          beforeFn.apply(this, arguments); // 'this' is context
        }
        oFn.apply(this, arguments);
        if (afterFn){
          afterFn.apply(this, arguments); // 'this' is context
        }
        if (aroundFn){
          aroundFn.apply(this, arguments);
        }
      };
    };
  return function(opt){
    if (opt && typeof opt === "object" && !opt.length) {
      options = opt;
      if (options.target && checkContext()) {
        if (options.before && typeof options.before === "function") {
          beforeFn = options.before;
        }
        if (options.after && typeof options.after === "function") {
          afterFn = options.after;
        }
        if (options.around && typeof options.after === "function") {
          aroundFn = options.around;
        }
        run();
      }
    }
  };
})();
// test examples
// ----------------- aop modify global function ---------------//
function test(name, age) {
  console.log("test fn. name = "   name   " age: "   age);
}
aop({
  target: "test",
  before: function() {
    console.log("aop before");
  },
  after: function() {
    console.log("aop after");
  },
  around: function() {
    console.log("aop around");
  }
});
// run
test("adam", 6);
// ----------------- aop test modify method in an object ---------------//
var myobj = {
  myName: "testName",
  sayName: function() {
    console.log(this.myName);
  },
  childObj: {
    age: 6,
    say: function() {
      console.log(this.age);
    }
  }
};
aop({
  context: myobj,
  target: "sayName",
  before: function() {
    console.log("aop before say name = "   this.myName);
  },
  after: function() {
    console.log("aop after say name = "   this.myName);
  },
  around: function() {
    console.log("aop around say name = "   this.myName);
  }
});
// run
myobj.sayName();
aop({
  context: myobj.childObj,
  target: "say",
  before: function() {
    console.log("aop before say name = "   this.age);
  },
  after: function() {
    console.log("aop after say name = "   this.age);
  },
  around: function() {
    console.log("aop around say name = "   this.age);
  }
});
myobj.childObj.say();
$.extend({ 
  add:function(a,b){return a b;} 
}); 

//$.add(3,4);
//return 7 

其中 $(":root") 选择器为根选择器
它总是从<html>开始

希望本文所述对大家的javascript程序设计有所帮助。

jQuery添加一个为 add的“静态方法”,之后便可以在引入 jQuery 的地方,使用这个方法了.

本文由千赢国际官网发布于千赢网页手机版登入,转载请注明出处:JavaScript之AOP编程实例,jquery获得当前html页面源码

关键词: 千赢国际官网 千赢国际qy966