- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在尝试将一组跨度元素(使用 ng-repeat 创建)推送到 x 轴上的某个计算位置。
这是在指令中完成的,其中每个元素的位置是根据一些启发式计算的。
但是,这些元素并未居中,而是左对齐。当存在需要在上述位置居中的文本(可变长度)时,这会带来问题。
直观上,我们可以计算包含文本的元素的宽度,并从 translateX 位置偏移该宽度,但是 html 是在指令中编译的,并且渲染后的更改会导致明显的闪烁。
在下面的代码中,您可以想象垂直 |表示文本应居中的中点位置。
HTML:
<script src="http://ajax.googleapis.com/ajax/libs/angularjs/1.2.17/angular.min.js"></script>
<div ng-app="varApp" ng-controller="TodoCtrl">
<div class="outter">
<span class="inner" ng-repeat="i in items track by $index" ng-if="i.value != null" ng-style="i.style">
{{i.value}}
</span>
</div>
<div class="outter2">
<span class="inner" ng-repeat="i in items track by $index" ng-style="i.style">|</span>
</div>
</div>
CSS:
.outter {
position: absolute;
top: 40px;
z-index: 1;
width: 100%;
margin-left: 16px !important;
}
.outter2 {
position: absolute;
top: 10px;
z-index: 1;
width: 100%;
margin-left: 16px !important;
}
.inner {
posiiton: absolute;
cursor: default;
z-index: 1
color: #red;
}
JavaScript(片段):
angular.module('varApp', [])
.controller('TodoCtrl', function($scope) {
var items = $scope.items = [];
for(var i = 2; i <= 10; i++) {
var string = new Array(i).join('a');
items.push({
value: string,
style: {
// should be transform: translateX(calcValue(el))
marginLeft: (i * 10) + "px"
}
})
}
});
我已经尽可能地重现了该示例,您可以在这里找到它; http://jsfiddle.net/w3fs8efe/90/
更新:
我尝试切换到使用宽度设置为下一个元素起点的“盒子”,本质上是一个包含列的表格,但现在的问题是当宽度被分解以适应父元素时,lat 元素不会居中。
换句话说,还是没有运气!
最佳答案
通过将文本内容放入宽度等于开始位置和结束位置之间的偏移量的范围内,设法获得我想要的内容。
Javascript:
angular.module('varApp', [])
.controller('TodoCtrl', function($scope) {
var items = $scope.items = [];
for(var i = 2; i <= 10; i++) {
var string = new Array(i).join('a');
items.push({
value: string,
style: {
// should be transform: translateX(calcValue(el))
marginLeft: (i * 100) + "px",
minWidth: ((i+1) * 100) - (i * 100)
}
})
}
});
参见 fiddle :http://jsfiddle.net/w3fs8efe/91/
关于javascript - 在 translateX 后将跨度元素居中对齐,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/42701967/
我正在使用 css 属性 translateX 将 Sprite 围绕某个点旋转 360 度。 Sprite 按预期围绕该点旋转,但我想知道如何在 Sprite 旋转时获得“左”和“顶”值。使用 tr
我制作了一个无限幻灯片,看起来像猫头鹰旋转木马“中心”(https://owlcarousel2.github.io/OwlCarousel2/demos/center.html)。 我的问题是,当第
我用 CSS transform-translateX 编写了一个测试。动画有效,但对象不保持最终位置,返回到原始位置。 如何保持最终位置? 这里是 CSS: @-webkit-keyframes m
关闭。这个问题是not reproducible or was caused by typos .它目前不接受答案。 这个问题是由于错别字或无法再重现的问题引起的。虽然类似的问题可能是on-top
我正在尝试使用更多的 css 和更少的 Javascript 来制作动画。我遇到了动画三个不同盒子的问题。我通过添加 fadeShow 类使不透明度为 1,使框以不透明度淡入淡出。但是,我希望框看起来
我正在尝试构建一个照片 slider 。现在我不介意我做这件事的方式是否那么好。我想知道的是,为什么在我通过 jQuery 更改 TranslateX 值并将其打印到控制台后,它不会打印更改后的值?
我正在尝试为移动 webkit 创建一个图片库, 它实际上足够快的唯一方法是使用硬件加速的 translateX 。 我的问题是 div 在动画结束时收回了它的初始位置。我在左侧按钮上添加了 slid
body{ height: 100vh; display: flex; justify-content: center; align-items: center; } div {
$(document).ready(function() { var $window = $(window), $overlay = $('.example2'), rotatio
问题是,translateX 在动画之前没有改变它的位置。在示例中有问题的幻灯片是 #slide2,我在设置动画之前更改它的位置,但它仍然从错误的一侧设置动画。 如何解决该行为?使用 css left
TranslateX(-50%) 而不是将元素(.heading)放在中心,而是将它放在最左边 .heading { position: relative; top: 50%; left: 50%;
在我一直致力于开发的网站 (www.koa-de.nl) 上,我使用了以下代码来使导航栏居中: left: 50%; transform: translateX(-50%); 我使用它是因为 marg
我正在尝试将一组跨度元素(使用 ng-repeat 创建)推送到 x 轴上的某个计算位置。 这是在指令中完成的,其中每个元素的位置是根据一些启发式计算的。 但是,这些元素并未居中,而是左对齐。当存在需
我希望这个问题不要太具体,这样它就可以与其他问题相关... 我有两个元素,一个子元素和一个父元素,子元素使用 CSS 动画围绕父元素旋转。 月亮动画设置为使月亮在同一位置加载到行星顶部,但使用
我会获得如下效果:我可以通过 translateX 更改的全屏部分(从左到右)。 不幸的是,我第一次尝试移动整个包装器而不是它的内容: https://codepen.io/anon/pen/WPzB
我遇到了 translateX 属性的问题。 我希望导航菜单隐藏在右侧,当用户点击菜单图标时,导航 translateX 从右到左轻松过渡,当然导航菜单会在点击前隐藏。它以某种方式不起作用,这是代码:
这个问题在这里已经有了答案: Transform: translate(-50%, -50%) (2 个答案) How to apply multiple transforms in CSS? (
我正在尝试制作不同的类以进行对齐。 我希望能够像 class="left bottom" 使用 transform:translate 属性那样组合它。 问题是该属性正在被彼此覆盖。 如果您查看我的
我正在尝试在单击菜单项时为屏幕上的多个元素设置动画...除一个以外的所有动画都按需要工作。我想从右向左移动页面的主要内容(部分),而不是在其中滑动,只是出现而没有任何过渡。这是相关的 CSS 代码:
我想向右进行 5px 的短 translateX 过渡。我想我的显示器有问题。所有其他过渡都有效,只有这个无效... 这是我的代码: #content a.shake { display: inl
我是一名优秀的程序员,十分优秀!