在多个元素上运行JavaScript函数
Run JavaScript function on multiple elements..?
我是JavaScript(当然还有jQuery)的新手,所以我正在寻求一点帮助…这个JavaScript函数根据容器的div改变字体大小。
http://jsfiddle.net/pthjU/我需要它的工作为所有div(某一类,最终)-但它只从第一个抓取信息,并根据那一个调整它们的大小。任何想法吗?
不是在寻找复制/粘贴的答案,我想正确地完成这个。谢谢!
既然你想独立处理每个元素,你可以在你的插件中这样做,通过在那里做一个.each()
循环,而不是这样:
$.fn.textfill = function(options) {
var fontSize = options.maxFontPixels;
var ourText = $('span', this);
var maxHeight = $(this).height();
var maxWidth = $(this).width();
var textHeight;
var textWidth;
do {
ourText.css('font-size', fontSize);
textHeight = ourText.height();
textWidth = ourText.width();
fontSize = fontSize - 1;
} while (textHeight > maxHeight || textWidth > maxWidth && fontSize > 3);
return this;
}
应该是这样的:
$.fn.textfill = function(options) {
return this.each(function() {
var fontSize = options.maxFontPixels;
var ourText = $('span', this);
var maxHeight = $(this).height();
var maxWidth = $(this).width();
var textHeight;
var textWidth;
do {
ourText.css('font-size', fontSize);
textHeight = ourText.height();
textWidth = ourText.width();
fontSize = fontSize - 1;
} while (textHeight > maxHeight || textWidth > maxWidth && fontSize > 3);
});
};
你可以在这里测试
作为题外话,从老方法…this
已经是一个插件内部的jQuery对象(注意我是如何直接调用.each()
的),没有必要把它包装在另一个jQuery对象(克隆它)。你做需要包装它在我的第二个例子内循环,因为在.each()
你指的是单独的DOM元素,而不是jQuery对象。
add .each() into
$('.post').each().textfill({ maxFontPixels: 500 }); <--- not sure if this works.. but
$('.post').each(function(){
jQuery(this).textfill({ maxFontPixels: 500 });
});
一定可以。
艾伦相关文章:
- 在终端中运行 JavaScript 时(使用 rhino),如何使用 print() 函数在一行中打印
- 向下滚动时运行javascript
- 在Android WebView中运行Javascript-onPageFinished循环
- 在父网页的iframe中运行JavaScript
- 有条件地运行javascript函数-Razor,HTML
- 如何通过获取用户输入和使用按钮来运行JavaScript函数
- 使用c#在Web服务器上运行JavaScript方法
- 单击链接时停止运行javascript
- 在浏览器检查表单之前运行javascript onsubmit
- 如何在表单提交事件后运行JavaScript*
- Mediawiki小部件将不会运行javascript
- 有没有一种方法可以在服务器端页面加载之前在加载时运行javascript
- 在GitHub上运行JavaScript Koans
- Chrome扩展:是否有一种方法可以运行JavaScript来获取页面上的内部html,并将其保存到扩展中的变量中
- 在不加载页面的情况下运行javascript
- [AutoIt]如何使用FF.au3在FireFox上的页面中运行javascript
- 仅在屏幕媒体上运行javascript/jquery,而不是打印
- Scala提升了如何运行javascript函数并将返回值存储在变量中
- 安卓系统:通过loadUrl运行javascript时,网络视图中的视频会冻结
- 在页面加载完成之前,使用URL参数运行JavaScript