- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在尝试创建一个 100% 宽度/高度的内容“ slider ”,它使用按钮和 anchor 链接跳转到幻灯片。
我不太擅长 javascript 或 jquery,所以我正在学习这个,但我已经让 slider 可以在 Chrome 和 Firefox 中工作,但在 Safari 中遇到了巨大的问题。代码如下:
var $proj = $('div.project') //Cache your DOM selector
visible = 1, //Set the number of items that will be visible
indexProject = 0, //Starting index
endIndexProject = 9; //End index
$('.workR').click(function(){
if(indexProject < endIndexProject ){
indexProject++;
$proj.animate({'left':'-=9.0909%'});
}
});
$('.workL').click(function(){
if(indexProject > 0){
indexProject--;
$proj.animate({'left':'+=9.0909%'});
}
});
/* sub project nav */
$("#one").click(function(e) {
indexProject = 0;
$proj.animate({'left':'0%'});
});
$("#two").click(function(e) {
indexProject = 1;
$proj.animate({'left':'-9.0909%'});
});
$("#three").click(function(e) {
indexProject = 2;
$proj.animate({'left':'-18.181334059343435%'});
});
$("#four").click(function(e) {
indexProject = 3;
$proj.animate({'left':'-27.272243150252528%'});
});
$("#five").click(function(e) {
indexProject = 4;
$proj.animate({'left':'-36.363152241161615%'});
});
$("#six").click(function(e) {
indexProject = 5;
$proj.animate({'left':'-45.454143287515365%'});
});
$("#seven").click(function(e) {
indexProject = 6;
$proj.animate({'left':'-54.544854594875545%'});
});
$("#eight").click(function(e) {
indexProject = 7;
$proj.animate({'left':'-63.63566105915084%'});
});
$("#nine").click(function(e) {
indexProject = 8;
$proj.animate({'left':'-72.72647748412166%'});
});
$("#ten").click(function(e) {
indexProject = 9;
$proj.animate({'left':'-81.81728394679116%'});
});
基本上所有项目 div 都是一个非常长的 div 的一部分,并且通过单击左右箭头按其宽度移动。 anchor 链接工作正常。
在第一张幻灯片上,单击向右箭头会重复显示第二张幻灯片,然后向左箭头不会返回到第一张幻灯片,而是会转到空白屏幕,因为现在位于 style="left: -72.72099260025185 %;”而不是回到零。
在检查代码时的第二张幻灯片上,并非所有幻灯片都沿着相同的百分比移动,而是它们都以稍微不同的百分比移动。
如果有人能解释为什么这在 Safari 中不起作用并为我指明正确的方向,我将不胜感激!我找到的答案有点像砖墙,不知道下一步该做什么。谢谢。
编辑
好吧,我现在知道在 Safari 中动画百分比是有问题的,所以现在我知道是百分比导致了不稳定的行为。进一步的挖掘让我找到了这段代码:
percent = 0.90909;
add_width = (percent*$proj.parent().width())+'px';
$proj.animate({'left': '-='+add_width}, 500);
它可以工作,但显然在调整浏览器大小时表现得不太像我想要的那样。是否有任何解决方法可以使百分比在 Safari 中工作,或者有一种方法可以使像素计算的内容针对 Safari?意识到我可能在这里捕获了救命稻草吗?!哈。
最佳答案
我知道这个问题已经很老了,但是由于没有人回答,而且我刚才在 Safari 中遇到了类似的问题...如果你的父容器是 100% 宽度并且该宽度与视口(viewport)大小相同(浏览器窗口宽度)...那么你可以使用这个:
$proj.animate({'left': '-=100vw' }, 500); //Where 100vw is 100% of the viewport width.
如果您的父容器没有视口(viewport)那么宽,您会遇到问题,但在大多数情况下,通过一些快速数学计算,您可以弄清楚计算结果可能是什么。无论如何,您可以在这里找到更多有用的信息:http://caniuse.com/#feat=viewport-units
关于jquery - Safari 中留下的 jquery animate 问题,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/18279914/
目前,我在单击我的正文时打开一个新选项卡,但它将焦点更改为子窗口。但我想通过留下窗口来做到这一点,这样弹出窗口就不会被阻止,并且我可以将焦点放在当前窗口上。 以下代码当前正在运行 /** * For
我有一个带有线性渐变的 css 背景图像。 CSS 代码: .footer-about { display: flex; align-items: center; justif
在服务中包含以下代码(假设在快速端点上): async function (res, req, next) { const fetch = require('node-fetch'); awa
我正在使用 IImageList 和 SHGetFileInfo 为任何给定路径提取巨型图标。一旦我有了它,然后我使用 DrawIconEx 将 HICON 渲染到 HBITMAP 中,最终使用 GD
我有图表并计算了网络密度,现在我应该只保留具有最大权重的分支(网络密度的前 10%,例如 200 中权重最大的 20 个分支)。我找不到该怎么做? 最佳答案 这个问题有点令人困惑,因此,如果稍后出现更
我一直在尝试使用 jquery 创建一种效果,当您将鼠标移到一个 div 上时,整个 body 都会移动,并沿着它经过的点留下一条轨迹。我创建了一个可以使整个 body 移动的功能,但我找不到离开轨迹
我想在桌面上显示放大和缩小图标(控件),而仅在移动设备上浏览时显示 gps 图标。我正在使用这个 css https://unpkg.com/leaflet@1.1.0/dist/leaflet.cs
相关代码(索引为数组大小): typedef struct elemento { unsigned long linha; unsigned long coluna; doub
我有一个 div,因此当我单击时,它会切换为展开或缩回。它在所有浏览器上都运行良好,尽管有一点让我很感兴趣。在谷歌浏览器上,当它缩回时,它会在运动中留下细线。 www.rezoluz.com/logi
每当我的应用程序尝试通过调用 CreateDIBSection() 或使用 LR_CREATEDIBSECTION 标志调用 LoadImage() 来创建 DIB 部分时,它似乎都会成功返回。它返回
我想在 Protractor 测试中脱离 Selenium 控制流。 以下是我迄今为止遇到的步骤和问题: 1。逐个测试禁用它 我的第一个想法是使用 SELENIUM_PROMISE_MANAGER 以
我正在构建一个部署在 CentOS 7.2 上的 ASP.Net Core (netcore 1.1) 应用程序。 我有一个通过 System.Diagnostics.Process 调用外部进程(也
我正在为我的网站创建一个聊天小部件。用户将能够输入纯文本 - 没有 html。 为了消除 HTML 标记并允许用户使用“”,我正在接受他们的输入并在用户屏幕的输入上使用 strip_tags() 和输
我是一名优秀的程序员,十分优秀!