- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我已经覆盖了基本默认的 page.xml,包括:jquery 延迟加载插件作为 head 部分中的第一个 jquery 脚本。然后紧接着,我有一个 no_conflict.js,其中只包含:
var $jq191= jQuery.noConflict();
然后page.xml包含所有其他javascript框架,例如prototype和effects.js、dragdrop.js等。
现在我最初实现我的网站时没有使用 magento,而是使用延迟加载插件。使用延迟加载插件,我在图像加载时添加了淡入效果。没有magento也能正常工作,一旦我添加了magento,当图像淡入时就会出现可怕的闪烁,这种情况只发生在谷歌浏览器中。因为我知道magento会发生这种情况,所以我一一删除了magento中包含的脚本,发现一旦删除effects.js,问题就解决了。
Effects.js 很难理解,而且我是 jquery/javascript 的新手,所以我想知道是否有人可以阐明这个问题。任何帮助将不胜感激。谢谢。
来自 page.xml:
<block type="page/html_head" name="head" as="head">
<action method="addJs"><script>jquery/jquery-1.9.1.min.js</script></action>
<action method="addJs"><script>jquery/no_conflict.js</script></action>
<action method="addJs"><script>prototype/prototype.js</script></action>
<action method="addJs"><script>lib/ccard.js</script></action>
<action method="addJs"><script>prototype/validation.js</script></action>
<action method="addJs"><script>scriptaculous/builder.js</script></action>
<action method="addJs"><script>scriptaculous/effects.js</script></action>
<action method="addJs"><script>scriptaculous/dragdrop.js</script></action>
<action method="addJs"><script>scriptaculous/controls.js</script></action>
<action method="addJs"><script>scriptaculous/slider.js</script></action>
<action method="addJs"><script>varien/js.js</script></action>
<action method="addJs"><script>varien/form.js</script></action>
<action method="addJs"><script>varien/menu.js</script></action>
<action method="addJs"><script>mage/translate.js</script></action>
<action method="addJs"><script>mage/cookies.js</script></action>
<block type="page/js_cookie" name="js_cookies" template="page/js/cookie.phtml"/>
<action method="addCss"><stylesheet>css/styles.css</stylesheet></action>
<action method="addItem"><type>skin_css</type><name>css/styles-ie.css</name><params/><if>lt IE 8</if></action>
<action method="addCss"><stylesheet>css/widgets.css</stylesheet></action>
<action method="addCss"><stylesheet>css/print.css</stylesheet><params>media="print"</params></action>
<action method="addItem"><type>js</type><name>lib/ds-sleight.js</name><params/><if>lt IE 7</if></action>
<action method="addItem"><type>skin_js</type><name>js/ie6.js</name><params/><if>lt IE 7</if></action>
</block>
来自 no_conflict.js:
var $jq191= jQuery.noConflict();
来自 local.xml:
<?xml version="1.0"?>
<layout>
<default>
<reference name="head">
<action method="addItem">
<type>skin_js</type>
<name>js/jquery.lazyload.js</name>
</action>
<action method="addItem">
<type>skin_js</type>
<name>js/loadlazy.js</name>
</action>
<action method="addItem">
<type>skin_js</type>
<name>js/vendor/bootstrap.min.js</name>
</action>
<action method="addItem">
<type>skin_js</type>
<name>js/jquery.fancybox.pack.js</name>
</action>
<action method="addItem">
<type>skin_js</type>
<name>js/jquery.fancybox-media.js</name>
</action>
<action method="addItem">
<type>skin_js</type>
<name>js/vendor/modernizr-2.6.2-respond-1.1.0.min.js</name>
</action>
<action method="addCss"><stylesheet>css/jquery.fancybox.css</stylesheet></action>
</reference>
</default>
</layout>
来自 loadlazy.js:
$jq191(document).ready( function( evt ){
$jq191("img.lazy").lazyload({effect: "fadeIn"});
$jq191(".product-popup").fancybox({
maxWidth : 800,
maxHeight : 600,
fitToView : false,
width : '70%',
height : '70%',
autoSize : false,
closeClick : false,
openEffect : 'none',
closeEffect : 'none',
type: 'iframe',
helpers : { overlay : { locked : false,
} }
});
});
来自附件.phtml:
只需在 img 标签上将类设置为“lazy”:
<img style="display: block; position:absolute; top: 50%; left:50%;
margin-left:<?php echo strval(-1*intval( $this->helper('catalog/image')->init($_product, 'image')->getOriginalWidth())/2); ?>px;
margin-top:<?php echo strval(-1*intval($this->helper('catalog/image')->init($_product, 'image')->getOriginalHeight())/2); ?>px"
class="lazy" id="lazy.images#<?php echo $_iterator; ?>"
src="<?php echo $this->getSkinUrl("img/product-placeholder.png"); ?>"
data-original="<?php echo $this->helper('catalog/image')->init($_product, 'image'); ?>"
height="<?php echo $this->helper('catalog/image')->init($_product, 'image')->getOriginalHeight(); ?>"
width="<?php echo $this->helper('catalog/image')->init($_product, 'image')->getOriginalWidth(); ?>"
alt="<?php echo $this->stripTags($this->getImageLabel($_product, 'image'), null, true); ?>" />
最佳答案
好的,问题就在这里 - 我将为您提供一些解决方案
jquery.lazyload.js
触发一个名为“appear”的事件 - 由于 jQuery trigger()
方法的编写方式,它将尝试触发元素上的方法并触发事件。 Scriptaculous 中的 Effects 方法将 appear()
方法添加到 Element 原型(prototype)。 Scriptaculous appear()
以及延迟加载 fadeIn()
都会触发,这就是当 2 个方法尝试更改元素的不透明度时出现闪烁的情况。同一时间。
轻松修复
在您的effects.js 副本中,最后一行是
Element.addMethods(Effect.Methods);
如果删除该行,它将从 Element 原型(prototype)中删除 Scriptaculous Effects 方法,并且应该可以解决眼前的问题。但是,如果任何其他插件依赖于 Element 原型(prototype)上的 Effects 方法,它们将开始失败。但如果您正在使用这些方法,您可以将它们更改为使用匿名方法。即
$('myelement').appear();
// changes to
Effect.Appear('myelement');
硬修复
在您的副本中
jquery.lazyload.js
查找出现事件的“appear”触发器和 observe()
/on()
并将事件名称更改为其他名称 - 这将需要更多调试因为第一次可能不起作用。还要确保找到所有实例,以便所有内容都发生更改。
关于jquery - 为什么magento安装的scriptaculous中的effects.js与Mike Tuupola的lazy-load jquery插件冲突,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/15713936/
我刚刚开始了解@ngrx/store 和@ngrx.effects,并在我的Angular/Ionic 应用程序中创建了我的第一个效果。它第一次运行正常,但如果我再次将事件发送到商店(即再次单击按钮时
是否可以将所有自定义表达式保存在外部 .jsx 文件中,以便我可以从项目内部调用它们? 例如,假设我有一个我经常使用的表达式,它将人偶工具指向一个空对象的位置。我知道我可以将该表达式转换为一个可以接受
关闭。这个问题是opinion-based .它目前不接受答案。 想要改进这个问题? 更新问题,以便 editing this post 可以用事实和引用来回答它. 关闭 6 年前。 Improve
谁能帮我指出正确的方向,如何在位图上使用这些 Android 4.0 以来可用的 GPU 加速效果? 文档指出例如“它们必须绑定(bind)到 GL_TEXTURE_2D 纹理图像”。但最好的方法是什
我有一个带有背景图像的大 UIButton,上面有五个小的不可见 UIButton。我想在按下一个不可见的小按钮时触发大按钮的突出显示效果。我怎样才能做到这一点? 请帮忙。非常感谢! 最佳答案 为所有
function* rootSaga() { yield all(sagas.map(saga => fork(saga))); } sagaMiddleware.run(rootSaga);
您好,我在将 Li 设置为事件选项卡时遇到问题,我已经添加了悬停效果但是如何添加事件选项卡?。我使用 Angular 的 ng-show 和 ng-hide 来更改 li 中的图标。这是我的代码
我已经将 redux-saga 升级到最新的 0.15.x 版本,并且我已经在 [...effects] 方面解决了很多弃用问题,取而代之的是 all([.. .effects]), 请更新你的代码
我试图理解在组件函数中产生副作用与在没有传入依赖项数组的效果中产生副作用(因此应该在每次渲染时触发)之间的实际区别。据我观察,它们都以相同的频率运行。我意识到效果允许在适当的时间进行清理,但我只是对清
当谈到排队 jQuery Effects 和 jQuery UI Effects 时,我真的很困惑。当我这样做时 $('#div_id').effect('bounce').effect('shake
我正在制作故障文字效果,效果非常好。 现在我正在尝试创建一个书写效果,效果也非常好! 但是两者一起都有一个小错误。 当我将鼠标悬停在文本上时,毛刺效果起作用,但是当书写效果向文本添加一个字母时,这个字
相关,但不是修复:jQuery issue - # has no method 当我尝试在 jquery 中使用 effect 函数时,出现错误 Object [object Object] has
我有一个具有四个 ngrx 操作的 Angular (2) 应用程序: 开始 不被 reducer 处理(没有状态变化) ngrx Effect 调用异步任务并映射到 SUCCESS 或 ERROR
在第16项:“使const成员函数线程安全”中有一段代码如下: class Widget { public: int magicValue() const { std::lock
这个问题不太可能帮助任何 future 的访问者;它只与一个小的地理区域、一个特定的时间点或一个非常狭窄的情况有关,这些情况并不普遍适用于互联网的全局受众。为了帮助使这个问题更广泛地适用,visit
下一行中的最后一行继续生成“警告 C4552:'<=':运算符无效;预期运算符有副作用”错误,但我没有看到任何错误... void countDays(void) { int i=0; if (bir
当我在列表框中使用滚动查看器时,当我通过触摸滚动到达列表框的末尾时,我的整个窗口都在弹跳。当我使用鼠标滚轮时,此行为不会出现。我怎样才能禁用这种过度滚动/橡皮筋效果/回弹效果/弹跳效果。 我在 Win
第 3.5.4 节讨论了有效不可变对象(immutable对象),也就是说,一旦一个对象被安全且完整地构建,它的状态就不会被任何代码路径的任何代码改变。 Goetz 爵士举了一个例子: For exa
我有一部电影在后期效果中没有背景的关键颜色,但背景仍然是静止的。 我想检测在静止背景前行走的 2 个人的运动并将他们带到前面,这样我就可以在背景上创建效果。 那有可能吗?我使用女巫效果吗? 最佳答案
在基于类的组件中: componentDidMount() { axios.get('https://jsonplaceholder.typicode.com/posts').then((re
我是一名优秀的程序员,十分优秀!