- android - RelativeLayout 背景可绘制重叠内容
- android - 如何链接 cpufeatures lib 以获取 native android 库?
- java - OnItemClickListener 不起作用,但 OnLongItemClickListener 在自定义 ListView 中起作用
- java - Android 文件转字符串
我想让我的网站同时支持 LTR 和 RTL 语言。
我想要的是,如果某些元素中加载的文本是 RTL,则将方向切换到 RTL。同样对于输入,当用户键入文本时,如果它是 RTL 并且将方向更改为 RTL,它应该触发。
例如 Facebook 正在这样做。如果您在搜索中键入一些阿拉伯文本,它会自动将方向切换为 RTL
没有通过谷歌搜索、任何脚本等找到任何练习教程。
我只发现属性 dir="auto"
会自动触发正确的方向,但看起来它不受旧浏览器的支持。
如何执行此操作的任何建议、教程、脚本都会有所帮助。
最佳答案
如果您只想支持在用户键入时将文本框上下文从 LTR 切换到 RTL,那么您将不得不监听输入事件(input、keypress、keydown 等,以最适合您的情况为准)并让代码决定文本框是 LTR 对齐还是 RTL 对齐。
不过,您应该注意,此算法并不是那么简单,而且不同产品的工作方式也不同。几个例子 -
这里没有对错之分,只有偏好和最适合您的算法。
您可以在此处阅读 Unicode 双向算法中的“强字符”:http://unicode.org/reports/tr9/
您可以看到一个示例,说明如何识别字符串中的第一个“强字符”以嵌入到 MediaWiki 的语言文件中,使用测试方向性的正则表达式(第 1 组是 LTR,第 2 组是 RTL)您可以使用这些来创建一个 JavaScript 方法,根据您认为合适的方式,根据第一个强字符或大多数字符设置文本区域的 dir=""属性: https://github.com/wikimedia/mediawiki/blob/6f19bac69546b8a5cc06f91a81e364bf905dee7f/languages/Language.php#L174
作为旁注,我只想指出在线支持 RTL/LTR 不仅仅是关于打字和文本框的。在 LTR 和 RTL 上下文之间切换还涉及 UI 调整,例如镜像内容的对齐方式和/或菜单和 Logo 等内容的位置。
如果您希望将页面翻译成 RTL 语言,这就很重要,这意味着您还需要镜像布局。如果您的唯一目标是在文本框中切换上下文,您不必担心这一点,但如果您想确保站点允许翻译,则需要考虑镜像 UI 和整个界面的方法。
关于javascript - 支持 RTL 语言,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/40922888/
iOS 应用程序,我们要显示来自服务器的新闻。使用UIlabel 当他只用一种语言而不考虑布局时,一切都是完美的(我们正在将布局 RTL 切换为 LTR,以适应不同的语言,包括阿拉伯语、希伯来语) 当
新版本的 React Native 已经发布了对 RTL 设备的支持: https://facebook.github.io/react-native/blog/2016/08/19/right-to
我将 Material UI 5 与 next.js 一起使用,并使用 emotion 和 stylis-plugin-rtl v2 实现了与此处文档完全相同的每个步骤: https://next.m
我知道如何在方向为内联时设置样式 foo div[dir="rtl"] { ....; } 但是如何设置样式 foo ? 两者的行为都符合预期(文本的右“对齐”),但我需要对内部的某些元素进行更精细
这个问题在这里已经有了答案: What is use of android:supportsRtl="true" in AndroidManifest xml file (4 个回答) 关闭4年前。
我正在使用material-ui和next和jss-rtl在我的react项目但是有一个问题页面仍然是ltr使用后 -rtl组件代码: import React from "react"; impor
我敢发誓,vivado 有一个错误,它永远不会刷新对 RTL 文件、verilog 或 vhdl 所做的任何接口(interface)更改,在使用“添加模块”将其粘贴到“ block 设计”后....
我正在尝试将 react Material 模板添加到我的 reactJs 项目中。我修复了所有错误,但我无法修复这个错误 WARNING in ./node_modules/stylis-plugi
我在 android 中构建一个绘图应用程序,我在绘制矩形时注意到一个问题。应该根据语法绘制矩形 new Rect(left, top, right, bottom) 现在我的逻辑通过取起点 (sta
我将 Tinymce 编辑器安装到我的网站。现在我需要将默认方向设置为 RTL 而不是 LTR。您可以在下面看到-- tinymce.init({ selector: 'textar
我注意到没有 bottomEndRadius在形状中,而只是 bottomRightRadius 是否有任何解决方法来支持从右到左的布局? 最佳答案 我发现的唯一方法是为 R
我使用此代码来运行具有 RTL 支持的 Isotope $.Isotope.prototype._positionAbs = function( x, y ) { return { right:
尝试显示以数字开头的希伯来语字符串,总是在字符串末尾显示数字,如下所示:1. йום שйשй בבוקר 但我需要在文本右侧显示数字- 有什么解决办法吗? 它发生在 UILabel & UIText
我在 react-native 中创建了一个应用程序,当电话语言为 En 时一切正常,但是当我更改电话语言时,UI 崩溃并且一切都向后 我在用 "react": "16.6.3", "reac
WordPress 非常强大......但对于阿拉伯语和希伯来语等 RTL 语言却很弱......我需要让前端使用阿拉伯语,而管理区域则需要使用英语,当然还有 LTR。如果我使用阿拉伯语版本的Word
我想知道为什么将Camera2 API与RTL语言一起使用时,摄像机预览会有所不同。具体来说,我有两个问题: 使用RTL时,相机上是否有任何特定设置? 我正在通过OpenCV使用边缘检测。 OpenC
我正在尝试在阿拉伯语 RTL 页面中使用 jQuery 菜单。我可以将其设为 RTL,但图标应该是 ui-icon-carat-1-w 而不是 ui-icon-carat-1-e。我创建了jsfidd
我正在尝试在统一输入字段中编写波斯语。波斯语是从右到左的语言,其字母与阿拉伯语相似。 我找到了 library转换和更正文本。它工作得很好。当我将转换后的文本显示为 Debug.Log() 时,一切都
我的应用程序支持 4 种不同的语言,其中两种是从右到左编写的。 如果我从 android 系统更改语言然后启动我的应用程序,一切正常。我得到一个镜像布局 (RTL),甚至导航栏也是镜像的。 我的问题是
我正在设计一种布局,该布局在不同的 View 中同时包含英语和希伯来语(旨在从右到左)文本。当一行希伯来语文本超过一定长度时,它会变成从左到右书写(我认为这与长度有关,因为它在较短的文本上看起来很好,
我是一名优秀的程序员,十分优秀!