- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在使用 SVG 构建资源 map 。当用户单击单个元素时,我想在该元素的中心放置一个弹出框。然而,由于 map 是通过 CSS 旋转的,技术 like this one没有成功。
这是我的javascript:
Map.popup = function(e) {
var rect = $(this);
var offset = $(this).offset();
var rectWidth = $(this).attr('width').replace(/[^-\d\.]/g, '');
var rectHeight = $(this).attr('height').replace(/[^-\d\.]/g, '');
var centerX = offset.left - rectWidth/2;
var centerY = offset.top - rectHeight/2;
$('.popup').css({
'top' : centerY,
'left' : centerX,
});
}
这是标记:
<div id="map">
<svg width="1088px" height="1088px" xmlns="http://www.w3.org/2000/svg">
<g transform="translate(288.0 32.0) rotate(45 256.0 512.0)">
<rect id="0" x="8px" y="8px" width="51px" height="230px"></rect>
<rect id="1" x="67px" y="8px" width="112px" height="38px"></rect>
<rect id="2" x="187px" y="8px" width="144px" height="38px"></rect>
<rect id="3" x="339px" y="8px" width="165px" height="38px"></rect>
<rect id="4" x="67px" y="54px" width="112px" height="44px"></rect>
<rect id="5" x="187px" y="54px" width="144px" height="75px"></rect>
<rect id="6" x="339px" y="54px" width="35px" height="24px"></rect>
<rect id="7" x="382px" y="54px" width="122px" height="51px"></rect>
<rect id="8" x="339px" y="86px" width="35px" height="204px"></rect>
<rect id="9" x="67px" y="106px" width="52px" height="132px"></rect>
<rect id="10" x="127px" y="106px" width="52px" height="132px"></rect>
<rect id="11" x="382px" y="113px" width="122px" height="78px" class=""></rect>
<rect id="12" x="187px" y="137px" width="144px" height="70px"></rect>
<rect id="13" x="382px" y="199px" width="122px" height="91px"></rect>
<rect id="14" x="187px" y="215px" width="144px" height="65px"></rect>
<rect id="15" x="8px" y="246px" width="171px" height="58px" class="selected"></rect>
<rect id="16" x="187px" y="288px" width="144px" height="70px"></rect>
<rect id="17" x="339px" y="298px" width="165px" height="60px" class=""></rect>
<rect id="18" x="8px" y="312px" width="171px" height="50px"></rect>
<rect id="19" x="187px" y="366px" width="144px" height="74px"></rect>
<rect id="20" x="339px" y="366px" width="165px" height="28px"></rect>
<rect id="21" x="8px" y="370px" width="171px" height="58px"></rect>
<rect id="22" x="339px" y="402px" width="165px" height="38px"></rect>
<rect id="23" x="8px" y="436px" width="171px" height="70px"></rect>
<rect id="24" x="187px" y="448px" width="87px" height="58px"></rect>
<rect id="25" x="282px" y="448px" width="49px" height="58px"></rect>
<rect id="26" x="339px" y="448px" width="165px" height="58px"></rect>
<rect id="27" x="8px" y="514px" width="171px" height="67px"></rect>
<rect id="28" x="187px" y="514px" width="87px" height="67px"></rect>
<rect id="29" x="282px" y="514px" width="49px" height="67px"></rect>
<rect id="30" x="339px" y="514px" width="19px" height="44px"></rect>
<rect id="31" x="366px" y="514px" width="46px" height="44px"></rect>
<rect id="32" x="420px" y="514px" width="84px" height="22px"></rect>
<rect id="33" x="420px" y="544px" width="84px" height="69px"></rect>
<rect id="34" x="339px" y="566px" width="73px" height="53px"></rect>
<rect id="35" x="8px" y="589px" width="171px" height="55px"></rect>
<rect id="36" x="187px" y="589px" width="24px" height="36px"></rect>
<rect id="37" x="219px" y="589px" width="112px" height="36px"></rect>
<rect id="38" x="420px" y="621px" width="84px" height="71px"></rect>
<rect id="39" x="339px" y="627px" width="73px" height="99px"></rect>
<rect id="40" x="187px" y="633px" width="24px" height="105px"></rect>
<rect id="41" x="219px" y="633px" width="112px" height="105px"></rect>
<rect id="42" x="8px" y="652px" width="103px" height="36px"></rect>
<rect id="43" x="119px" y="652px" width="60px" height="179px"></rect>
<rect id="44" x="8px" y="696px" width="103px" height="49px"></rect>
<rect id="45" x="420px" y="700px" width="84px" height="26px"></rect>
<rect id="46" x="339px" y="734px" width="165px" height="46px"></rect>
<rect id="47" x="187px" y="746px" width="24px" height="85px"></rect>
<rect id="48" x="219px" y="746px" width="112px" height="34px"></rect>
<rect id="49" x="8px" y="753px" width="103px" height="122px"></rect>
<rect id="50" x="219px" y="788px" width="112px" height="43px"></rect>
<rect id="51" x="339px" y="788px" width="165px" height="43px"></rect>
<rect id="52" x="119px" y="839px" width="92px" height="177px"></rect>
<rect id="53" x="219px" y="839px" width="46px" height="177px"></rect>
<rect id="54" x="273px" y="839px" width="58px" height="53px"></rect>
<rect id="55" x="339px" y="839px" width="58px" height="53px"></rect>
<rect id="56" x="405px" y="839px" width="99px" height="53px"></rect>
<rect id="57" x="8px" y="883px" width="103px" height="39px"></rect>
<rect id="58" x="273px" y="900px" width="124px" height="116px"></rect>
<rect id="59" x="405px" y="900px" width="19px" height="116px"></rect>
<rect id="60" x="432px" y="900px" width="72px" height="116px"></rect>
<rect id="61" x="8px" y="930px" width="103px" height="86px"></rect>
</g>
</svg>
</div>
您可以在此处查看 map 的一个版本(及其不完美的定位):http://cityasacampus.org/map/ .
关于如何更好地定位每个中心的任何想法?
最佳答案
正如@sjm 所指出的,您可以使用getBoundingClientRect()
来获取您的“真实”高度/宽度,但它不适用于$(this)
.
Map.popup = function(e) {
var rect = $(this);
offset = $(this).offset(),
canvas = document.getElementById(rect.prop('id')),
rectWidth = canvas.getBoundingClientRect().width,
rectHeight = canvas.getBoundingClientRect().height,
popoverWidth = 250,
popoverHeight = $('.popup').height(),
centerX = offset.left - popoverWidth + rectWidth/2,
centerY = offset.top + rectHeight/2;
$('.popup').css({
'top' : centerY,
'left' : centerX,
});
}
还有你的 centerX
和 centerY
是错误的,我已经改正了。
干杯!
关于javascript - 将弹出框定位在元素的中心,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/31736181/
我必须从我的网站中删除()一些iem,然后将它们追加()回来,但是当我追加它们时,它们出现在不同的地方,而我希望它们完全显示在它们以前的同一个地方是。 有什么解决办法吗? 这是一个沙箱,请随意更新(注
一个。图片 (960x7)b. div(宽度:960,填充:10) 我想定位 (a),使其距顶部 50 像素,居中。我想将 (b) 放置在 (a) 的正下方,没有空格。 我的 CSS 如下: @cha
放置某物的正确方法是什么?我有一个在中心显示博客文章的 div。 "" rel="bookmark"> BY LOUIS MOORE ON " pubdate>
很难说出这里要问什么。这个问题模棱两可、含糊不清、不完整、过于宽泛或夸夸其谈,无法以目前的形式得到合理的回答。如需帮助澄清此问题以便重新打开,visit the help center . 关闭1
我已经成功地使用了 position:fixed 设置 CSS/CSS3 并且工作得很好! 我几天前看到了这个,想知道他们是如何实现向下滚动时发生的效果的,菜单栏在滚动前处于一个位置,然后转到顶部并自
关闭。这个问题不符合Stack Overflow guidelines .它目前不接受答案。 这个问题似乎与 help center 中定义的范围内的编程无关。 . 关闭 7 年前。 Improv
接口定义 能够对于文字、段落乃至任何元素的精准定位 并做出增删改查,都是在开发一款富文本编辑器时一项最基本也是最重要的功能之一。让我们先来看看Slate中对于如何在文档树中定位元素是怎么定义的
例如,使用 WPF 在选项卡控件的最左上角定位三个 tabitem 和在最右上角定位一个 tabitem 的正确方法是什么? 我尝试通过更改边距将第四个 tabitem 向右移动,但这并没有产生好的结
我正在尝试使用 Javascript 创建一个跟随鼠标在页面上移动的东西。我希望它是米老鼠,我希望他的眼睛跟随鼠标移动他的眼球...这是我到目前为止的代码(从网络上的各个地方收集,因此归功于编写该部分
已关闭。此问题不符合Stack Overflow guidelines 。目前不接受答案。 这个问题似乎与 help center 中定义的范围内的编程无关。 . 已关闭 9 年前。 Improve
我试图将两个按钮放置在左上角。但它们始终位于顶部中心。 我已经尝试过这个: jp = new JPanel(); jp.setLayout(new GridBagLayout()); GridBagC
我在使用 JQuery 向下滑动功能时遇到问题。我可以让它正常工作,但是我向下滑动的元素的位置会根据视口(viewport)的大小而变化。我想做的是将它与它滑动的元素联系起来。 This JSfidd
我正在尝试创建一个棋盘,并将其放置在屏幕中间,但到目前为止我无法将它直接放在中间。我不想将位置硬编码到屏幕上,因为我要处理不同的屏幕尺寸。 var winsize = cc.director.
我正在尝试从 mysql 中的 2 个字符串点之间提取数据,我的示例脚本是 'otherdata&p1=textneeded&otherdata' 我需要拉出“textneeded”位,“P1=”是起
如何在 JavaFX 中设置按钮的位置?我的代码: bZero = new Button(); bZero.setPrefSize(45, 20); mainPane.getChildren().ad
我有一个 iPhone 应用程序,我可以在其中显示一系列图像。当用户点击图像时,我需要将该图像带到第一个位置,表明它是所选图像。我可以通过子类化实现 uiscrollview 中的点击。但是我无法将
在下图中,它显示了一个image、textbox 和一个css menu image 我的 CSS 菜单非常完美。我终于按照我需要的方式得到了它。我的问题是我需要导航栏中央的文本框,然后我需要我的图像
我必须创建一个看起来像这样的 div id为2的div应该出现在图片的右下角,图片的大小不固定id=2的div应该应用什么css id =1 的 div 没有定义位置,所以使用默认值,图像也是
如何将我的文本和图像对齐在同一行? 每当我使用 padding 或 margins 时,它就会崩溃到我正在使用的圆形图像中。 #alignPhoto { padding-right: 50px;
简单的问题,如何定位具有整个页面引用的元素? 在我的例子中,我在标题中得到了一个 float 图像,然后是 2 组标题。当我使用时: text-align: center; 它使用图像宽度端和页面其余
我是一名优秀的程序员,十分优秀!