我正在尝试重新创建 New York Times Fashion Week 中使用的笛卡尔失真效果页。但是,他们使用 D3 版本 3 和 D3js 的鱼眼插件,但不适用于 D3 版本 4。
由于我们做的整个元素都在 D3 V4 中,我无法降级到 D3 Version 3。
有没有其他方法可以使用 CSS 和 jquery 实现这种效果?
我已经尝试过这是我到目前为止的位置:preview
window.onload = run;
function run() {
if ($('.overlayDiv').css('display') != 'none') {
var container = d3.select('.overlayDiv');
container.empty();
var val = parseInt(5);
var overlayWidth = $(".overlayDiv").width();
var vwidth = (overlayWidth / (val));
console.log(vwidth);
for (i = 0; i < val; ++i) {
var div = container.append("div").style("width", vwidth + "px")
.style("height", "100%")
.style("background", "rgb(75, 123, 175)")
.style("float", "left")
var year = div.text(i)
.attr("class", "summary")
.style("text-align", "center")
.style("font-size", "32px")
.style("font-weight", "bold")
.style("line-height", "100px").style("color", "white")
.on('mouseover', function() {
d3.select(this)
.transition().style('width', $(".overlayDiv").width() / 2 + "px")
.style("background", "rgba(90, 90, 90, 0.78)")
$('.summary').not(this).each(function() {
$(this).css("width", (overlayWidth / 3) / (val));
});
})
.on('mouseout', function() {
d3.select(this)
.transition().style('width', vwidth + "px")
.style("background", "rgb(75, 123, 175)")
$('.summary').not(this).each(function() {
$(this).css("width", vwidth);
});
})
}
$('.overlayDiv').show();
//$('.overlayDiv').text(this.firstChild.nextSibling.innerHTML);
$('.overlayDiv').addClass("overlayActive");
$('.overlayDiv').removeClass("overlayInactive");
} else {
var container = d3.select('.overlayDiv');
container.empty();
$('.overlayDiv').hide();
$('.overlayDiv').text("");
$('.overlayDiv').removeClass("overlayActive");
$('.overlayDiv').addClass("overlayInactive");
}
}
如何改进这个,达到纽约时报看到的效果?
最佳答案
您可以仅使用 css 实现此效果。
代码笔:http://codepen.io/hunzaboy/pen/qrRpzZ
body {
background: #444;
}
.items {
height: 128px;
/*change this as per your requirments */
overflow: hidden;
display: flex;
}
.item {
box-shadow: inset 0 0 0 1px #000;
align-items: center;
transition: flex 0.2s;
background-size: cover;
background-position: center;
flex: 1;
}
$class-slug: item !default;
@for $i from 1 through 20 {
.#{$class-slug}-#{$i} {
background-image: url("https://randomuser.me/api/portraits/women/#{$i}.jpg");
}
}
/* Flex Items */
.item>* {
/* flex: 1 0 auto; */
}
.item:hover {
flex: 3;
}
.item:hover ~ .item {
flex: 2;
}
关于javascript - CSS 的笛卡尔失真效果,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/42712573/
我在MiniTest::Spec和Capybara中使用以下规范:find_field('Email').must_have_css('[autofocus]')检查名为“电子邮件”的字段是否具有autofocus属性。doc说如下:has_css?(path,options={})ChecksifagivenCSSselectorisonthepageorcurrentnode.据我了解,字段“Email”是一个节点,因此调用must_have_css绝对有效!我做错了什么? 最佳答案 通过JonasNicklas得到了答案:No
我有一个div,它根据表单是否正确提交而改变。我想知道是否可以检查类的特定元素?开始元素看起来像这样。如果输入不正确,添加错误类。 最佳答案 试试这个:browser.div(:id=>"myerrortest").class_name更多信息:http://watir.github.com/watir-webdriver/doc/Watir/HTMLElement.html#class_name-instance_method另一种选择是只查看具有您期望的类的div是否存在browser.div((:id=>"myerrortes
我遇到了一个非常奇怪的问题,我很难解决。在我看来,我有一个与data-remote="true"和data-method="delete"的链接。当我单击该链接时,我可以看到对我的Rails服务器的DELETE请求。返回的JS代码会更改此链接的属性,其中包括href和data-method。再次单击此链接后,我的服务器收到了对新href的请求,但使用的是旧的data-method,即使我已将其从DELETE到POST(它仍然发送一个DELETE请求)。但是,如果我刷新页面,HTML与"new"HTML相同(随返回的JS发生变化),但它实际上发送了正确的请求类型。这就是这个问题令我困惑的
我开始了一个新的Rails3.2.5项目,Assets管道不再工作了。CSS和Javascript文件不再编译。这是尝试生成Assets时日志的输出:StartedGET"/assets/application.css?body=1"for127.0.0.1at2012-06-1623:59:11-0700Servedasset/application.css-200OK(0ms)[2012-06-1623:59:11]ERRORNoMethodError:undefinedmethod`each'fornil:NilClass/Users/greg/.rbenv/versions/1
rails新手。只是想了解\assests目录中的这两个文件。例如,application.js文件有如下行://=requirejquery//=requirejquery_ujs//=require_tree.我理解require_tree。只是将所有JS文件添加到当前目录中。根据上下文,我可以看出requirejquery添加了jQuery库。但是它从哪里得到这些jQuery库呢?我没有在我的Assets文件夹中看到任何jquery.js文件——或者直接在我的整个应用程序中没有看到任何jquery.js文件?同样,我正在按照一些说明安装TwitterBootstrap(http:
我正在尝试消除使用Bootstrap3的Rails4元素中的glyphicon错误。我没有使用任何Bootstrapgem将其添加到Assets管道中。我手动将bootstrap.css和bootstrap.js添加到各自的app/assets目录下,分别添加到application.css和application.js什么的我现在在网络浏览器的控制台中看到以下内容:GEThttp://localhost:3000/fonts/glyphicons-halflings-regular.woff404(NotFound)localhost/:1GEThttp://localhost:30
我有这个:AccountSummary我想单击该链接,但在使用link_to时出现错误。我试过:bot.click(page.link_with(:href=>/menu_home/))bot.click(page.link_with(:class=>'top_level_active'))bot.click(page.link_with(:href=>/AccountSummary/))我得到的错误是:NoMethodError:nil:NilClass的未定义方法“[]” 最佳答案 那是一个javascript链接。Mechan
我有一个使用twitterbootstrap和sass的Rails元素。scss文件结构化到文件夹中,所以我有更好的概述。现在我想为包含我的颜色等的全局变量定义一个文件,并将这些值传递给其他文件,这样我就有更少的冗余代码。虽然所有代码都已正确导入和应用,变量不起作用。这是当前的设置:样式表/application.css.scss/**=require_self*=require_tree*//*stylesheets/||–base/||–_reset.scss#Reset/normalize||–_typography.scss#Typographyrules||–componen
有没有一种方法可以在jekyll站点中包含自定义css标签,同时将markdown用于入口文件?例如,当我想突出显示某个段落时? 最佳答案 Markdown和YAMLFrontMatter都内置了这个。但你可以自己制作。比如说,您有foo.css想要包含在某些帖子中。在_posts/2013-02-03-higligting-foo.markdown中:---css:footitle:"DrupalImagecachesecurityvulnarabilitywithDDOSattackexplained"tags:[drupal,
我看到有关未找到文件min.map的错误消息:GETjQuery'sjquery-1.10.2.min.mapistriggeringa404(NotFound)截图这是从哪里来的? 最佳答案 如果ChromeDevTools报告.map文件的404(可能是jquery-1.10.2.min.map、jquery.min.map或jquery-2.0.3.min.map,但任何事情都可能发生)首先要知道的是,这仅在使用DevTools时才会请求。您的用户不会遇到此404。现在您可以修复此问题或禁用sourcemap功能。修复:获取文