- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
我需要确定足以显示可能包装的动态 HTML 字符串的最小宽度。如果没有自动换行,这很简单:创建一个 span
, 设置它的 innerHTML
并阅读 offsetWidth
.但是,我不确定如何强制换行...我看到的最简单的不完整方法是将所有空格替换为 <br/>
, 但线条不仅可以包裹在空格上,还可以包裹在例如在连字符上。
所以,基本上,我想要一个浏览器来布置某物。喜欢
Max.
word-
wrapped
string
<----->
屏幕外某处测量最长包含单词的宽度。有通用的方法吗?
编辑
即,没有换行:
function computeWidth (str) { // code to make it off-screen and caching omitted
var span = document.createElement ('span');
document.body.appendChild (span);
span.innerHTML = str;
return span.offsetWidth;
}
我将如何编写一个类似的函数来强制在 str
上换行? ,大概是在玩 span.style
?
最佳答案
您可以使用 CSS work-break
/word-wrap
并以编程方式插入软连字符( ­
,但我建议您阅读有关软连字符的跨浏览器问题,因为有很多 - 我通常将 unicode 用于软连字符(U + 00AD),但您的里程可能会有所不同),然后使用范围对象和测量光标从左侧偏移量来确定 javascript 的宽度。
我建议使用软连字符,因为即使是同一个浏览器通常也会根据操作系统/所使用的字典(在 OSX 上)的不同而以不同方式断词。如果这对您来说不是问题,您可以不使用软连字符。
Afaik 没有通用方法可以在 html/js 中获得您想要的内容(如果您使用的是 flash 之类的东西,情况会有所不同)。
范围对象: https://developer.mozilla.org/en-US/docs/Web/API/range
另一种方法是使用 canvas 对象,但您可能不会在那里获得准确的结果,因为现在影响浏览器中文本呈现的因素太多(字体、大小、字距、字距、...)
另一种方法是使用 <pre>
标签/whitespace: pre-wrap
,将字体设置为您通常使用的字体,然后通过插入换行符或从另一个 span/div/使用自动换行设置的任何内容复制它们来模拟中断词 - 我还没有测试过这个,但如果它有效,它可能比迭代范围对象更容易。
编辑:不仅在评论中,还有另一种解决方案:
以宽度 1px 开始你的容器,然后增加宽度,每次检查高度;当高度降低时,返回一步,你就得到了你的宽度。最简单的实现是使用 1px 增加/1px 减少,但您当然可以将其优化为使用类似于二进制搜索算法的东西,例如从 1px 开始,然后是 2px,然后是 4px 增加,然后同样向后,然后再次向前,依此类推,直到你得到 1px 步长的结果。但这只是在 1px inc/dec 解决方案太慢的情况下;)
关于html - 如何强制浏览器在可能的情况下中断文本?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/19097071/
我一直很难编辑我的 .htaccess 文件来一起做这三件事。我已经能够分别获得每个部分,但我只是不明白逻辑流程如何使它们全部工作。 这是我能够使用 bluehost support 上的演示进行整合
我制作的宏将模板工作簿保存为两个单独的文件。每个测试保存一个(位置 1、2、3 或 4),然后在另一个宏中使用每个测试的数据。第二个是保留用于备份的原始数据文件。现在的问题是每次我在每个位置运行测试并
我正在写一篇关于如何使用 OCaml 的模块系统而不是 Java 的 OO 系统(一个有趣的视角)的博客文章。我遇到了一些我不理解的关于强制的事情。下面是一个基本模块和两个包含它的模块: module
我有一段将被执行多次(5,000+)的代码,以及一个仅在第一次为真的 if 语句。我曾想过使用“FIRST”变量并每次都进行比较,但每次都检查它似乎是一种浪费,即使我知道它不需要。 bool FIRS
首先,我是 Perforce 的新手,我主要通过其文档进行学习。 因此,我们即将从 CVS 迁移到 Perforce,我最近学到了一个避免更改每个工作区的 P4CLIENT 的好方法,即在工作区根目录
我正在为一段代码编写测试,其中包含我试图涵盖的 IOException 捕获。 try/catch 看起来像这样: try { oos = new ObjectOutputStream(new
我正在尝试在新闻项目滚动之间添加延迟。我知道 $.each() 通过不等待动画完成来完成其工作,但我想知道如何制作它,以便一次向上滚动一个项目并等到最后一个动画完成后再继续在循环中。 $(functi
假设已经编写了一个方法,需要一个排序列表作为其输入之一。当然这将在代码中进行注释和记录,param 将被命名为“sortedList”,但如果有人忘记,则会出现错误。 有没有办法强制输入必须排序?我正
我正在尝试将传入请求重定向到 https://www.domain.com/和所有 https://www.domain.com/ {所有页面}并且没有什么麻烦。我试过的方法: 添加此行:Redire
我将如何实现以下内容: title_selection = raw_input("Please type in the number of your title and press Enter.\n%
我有一个登录表单,我需要强制关闭自动完成功能。我试过了 jquery: $('#login').attr("autocomplete", "off"); HTML: Javascript:docume
我想知道我应该怎么做才能强制从 dev 分支 merge 到我的 master 分支?使用“git merge dev”会导致很多冲突。但是,我不想单独处理它们。相反,我只是想使用我的 dev 分支中
当安装 Hl7.Fhir.DSTU2 和 Hl7.Fhir.R4 这两个 Nuget 包时,我们得到如下信息: DSTU2 包似乎在使用 Hl7.Fhir.Support.Poco 版本 3.4.0
我正在尝试让一个功能组件在 testFn 执行时强制重新渲染。我想使用状态来做到这一点(如果有更好的方法请说出来),这似乎成功地强制重新渲染但只有两次,然后什么都没有。 我构建了一个简单的演示来模拟这
默认情况下,g++ 似乎会省略未使用的类内定义方法的代码。示例 from my previous question : struct Foo { void bar() {} void baz(
我正在尝试使用 here 中介绍的技术使我的网站背景以比内容慢的速度滚动。我不希望背景固定,只希望更慢。 这是 HTML 的样子: .parallax { perspective: 1px;
我能找到的最相似的问题是 'how to create a row of scrollable text boxes or widgets in flutter inside a ListView?'
我有以下 eslint 配置: "object-curly-newline": ["error", { "ImportDeclaration": "never",
我正在使用 TinyMCE 插件并将 valid_elements 选项设置为: "a[href|target:_blank],strong/b,em/i,br,p,ul,ol,li" 即使没有列出数
您好,我想使用以下命令放置多行描述 p4 --field Description="MY CLN Header \\n my CLN complete description in two -thre
我是一名优秀的程序员,十分优秀!