穿着木屐跳舞——jQuery图表插件jqchart的使用
先上图:
前段时间,论坛上有不少版友问在Access里怎么做图表。——众所周知,尽管Access也有不少图表类型,但并不是做图表的最佳选择。Excel可以有更多选择,做得更漂亮。但是,在Access2010以后,似乎不支持Spreadsheet控件了……所以退而求其次,不妨考虑下jQuery吧。
jQuery的魅力在于它的UI和众多插件,然而在Access里却不是那么好用,主要表现在数据的交换上。你可能需要将Access里的数据转换为JSON文件,甚至Javascript脚本输出,然后再执行。——HTML不能直接读取Access数据,请原谅它的无能吧。(如果是PHP和MySQL则方便多了,当然,PHP需要安装运行环境)。
不过,也不是完全不能实现。例如,我们可以考虑把Access里的数据输出成js文件,然后再利用html来执行;又或者构造javascript语句,用DOM来执行。——本例正是这个方法。
但无论怎么说,都有一种穿着木屐跳舞的感觉,——实在不好施展。如果你留意过之前老汉写过的jQuery示例,就会发现,没几个是在Access里执行的。我想,原因也在于此吧。
顺便说一下,Access2010+IE11下的Webbrowser不支持 jQuery 1.5.1,建议使用里面的1.11版本(Access 2010 Or Access2003+IE11均支持)。
示例下载地址:http://www.office-cn.net/thread-119343-1-19.html
jQuery 插件开发指南
jQuery凭借其简洁的API,对DOM强大的操控性,易扩展性越来越受到web开发人员的喜爱,经常有人询问一些技巧,因此干脆写这么一篇文章给各位jQuery爱好者,算是抛砖引玉吧。
jQuery插件
那么首先我们来简单的看一下正统的 jQuery 插件定义方式:
(function ($) {
$.fn.插件名 = function (settings) {
//默认参数
var defaultSettings = {
} /* 合并默认参数和用户自定义参数 */
settings = $.extend(defaultSettings, settings);
return this.each(function () { //代码 }); //插件在元素内多次出现
} })(jQuery);
先来看模板中的第一行代码(当然我们要把这一行代码的后半部分给揪出来一起看,不然第一行就完全无意义了):
(function ($) {
})(jQuery);
这行代码其实是用于创建一个匿名函数。如果你对匿名函数和闭包不了解,将会对这种代码非常疑惑,那么强烈建议您阅读【详谈JavaScript 匿名函数及闭包】这篇文章。
jQuery 的继承方法 $.extend —— $.extend 在jQuery 插件开发中有个很重要的作用,就是用于合并参数。
$.fn.tip = function (settings) {
var defaultSettings = {
//颜色
color: \’yellow\’,
//延迟
timeout: 200 }
/* 合并默认参数和用户自定义参数 */
settings = $.extend(defaultSettings, settings);
alert(settings.input);
}
jQuery 插件定义第二种方式:
(function ($) {
//插件定义–更换名字
$.fn.tabpanel = function (method) {
var methods = $.fn.tabpanel.methods;
if (methods[method]) {
return methods[method].apply(this, Array.prototype.slice.call(arguments, 1));
} else if (typeof method === \’object\’ || !method) {
return methods.init.apply(this, arguments);
} else {
}
}
//支持的方法
$.fn.tabpanel.methods =
{
//初始化
init: function (p_options) {
tabpanelBind(p_options, this);
},
add: function (p_options) {
addTab(p_options, this);
tabpanelBind(p_options, this);
// debugger
} }
function add(p_options) {
var _defaults = {
id: \”\”
}
//内部实现略………
return _index;
}
})(jQuery);
调用 $(\”#team\”).tabpanel(\’add\’,\”\”);
本文作者及来源:Renderbus瑞云渲染农场https://www.renderbus.com
文章为作者独立观点不代本网立场,未经允许不得转载。