- xml - AJAX/Jquery XML 解析
- 具有多重继承的 XML 模式
- .net - 枚举序列化 Json 与 XML
- XML 简单类型、简单内容、复杂类型、复杂内容
首先,这里有一个非常相似的问题:
How to check if Font Awesome is loaded in web page with javascript?
我将尝试解释为什么我的问题不同。
我发现浏览器已经开始普遍阻止网络字体,这需要回退解决方案。使用普通字符范围字体,这很容易:
CSS:
font-family: Lato, "Lucida Grande", Tahoma, Sans-Serif;
但 Font awesome 更难,因为它使用正常字体范围之外的字符,并且不能有简单的单行 css 解决方案。
有几个选项可用,包括使用图像,或者在某些情况下使用其他字体的字符,类似于图标,但所有方法都需要一种方法来检查 font awesome 是否在各个客户端的浏览器中实际工作。
链接问题的答案说您可以使用以下代码检查是否加载了很棒的字体:
function css(element, property) {
return window.getComputedStyle(element, null).getPropertyValue(property);
}
window.onload = function () {
var span = document.createElement('span');
span.className = 'fa';
span.style.display = 'none';
document.body.insertBefore(span, document.body.firstChild);
if ((css(span, 'font-family')) !== 'FontAwesome') {
// add a local fallback
}
document.body.removeChild(span);
};
但是,我的本地回退从未执行过,因为 css(span, 'font-family')
实际上会返回 FontAwesome。我相信这是因为 css 文件导入没有问题,并且 css 说字体系列应该是 FontAwesome。事实仍然是 FontAwesome 无法正常工作。换句话说,接受的答案只检查 Font Awesome css 是否存在,而不检查网络字体本身是否因安全问题而被阻止。
另一个问题的 OP 在评论中阐明了他们问这个问题的原因:
I'm doing it because I'm writing a snippet of js that is going to be loaded in many different pages that I'm not sure are all gonna have font-awesome, if they don't I'm going to load it.
我的问题是浏览器阻止网络字体,我希望标题足够清楚,可以被视为一个单独的不同问题。该问题存在于 Windows 10 和 IE11 的组合设置中。我已经用尽所有选项来简单地关闭阻止字体的安全设置。
重复问题解释:
这个问题根本不是 suggested question 的重复问题.这与资源是否加载无关。资源的加载工作得很好。主机未被阻止。 Web 应用程序的呈现和显示是问题所在,这在原始问题中也有解释,但现在再次提到,因为有人建议将其作为副本关闭。
编辑,进一步阅读:
我努力关闭阻止网络字体的设置是 explained here
最佳答案
您正在使用的解决方案将不起作用,因为 window.getComputedStyle
不会告诉您渲染的字体,而是样式表中定义的字体、加载的或其他方式 ( ref )。您可以使用启发式方法:
window.onload = function() {
var fas = document.createElement("span");
fas.className = "fas fa-ambulance";
fas.style.position = "absolute";
fas.style.left = 0;
fas.style.top = 0;
fas.style.visibility = "hidden";
document.body.appendChild(fas);
window.setTimeout(function() {
var widthBefore = fas.offsetWidth;
fas.style.fontFamily = "asdf";
var widthAfter = fas.offsetWidth;
if (widthBefore === widthAfter) {
console.log("Font Awesome Blocked");
} else {
console.log("Font Awesome Loaded");
}
document.body.removeChild(fas);
}, 2000);
}
<link rel="stylesheet" href="https://use.fontawesome.com/releases/v5.7.1/css/all.css">
上面的代码创建了一个使用 Font Awesome 的元素,并将其宽度与强制使用后备字体的元素进行比较。宽度比较会告诉您浏览器是否也使用了 Font Awesome 的后备字体。
关于javascript - 如何检查客户端浏览器是否阻止了 font awesome?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/54578395/
我需要根据需要动态设置文本区域,但它不想正常工作。 JQuery 会自行检查,但无法检查是否已检查。但是当您在第二个单选框内单击时,始终需要文本区域。我尝试了很多次让它工作,但它仍然有问题。我添加了“
我需要在 Django 中进行 API 调用(某种形式),作为我们所需的自定义身份验证系统的一部分。用户名和密码通过 SSL 发送到特定 URL(对这些参数使用 GET),响应应该是 HTTP 200
我将在我的可移植 C 代码中使用 #warning 来生成编译时警告。但并非所有平台都支持 #warning。有什么方法可以找到该平台是否支持 #warning。 #ifdef warning
我编写了一个函数来检查某个数字是否存在于某个区间内。停止搜索的最佳方法是什么?这个: for (i = a; i <= b; i++) { fi = f(i); if (fi == c) {
我想知道在 c 中是否有一种方法可以检查,例如在 for 函数中,如果变量等于或不等于某些字符,而不必每次都重复进行相等性检查。如果我没记错的话,以这种方式检查相等性是不正确的: if (a == (
我有如下日志功能 void log_error(char * file_name, int line_num, int err_code) { printf("%s:%d:%s\n", fil
使用 ssh-keygen 生成的 key 对在 macOS 上可以有不同的格式。 macOS 可读的标准 PEM ASN.1 对象 SecKey API 带有文本标题的 PEM OpenSSH ke
我正在尝试编写一个 excel if 语句。我不熟悉使用 Excel 具有的所有额外功能。我正在使用一个名为 importXML() 的函数.我正在尝试检查我正在使用的函数是否生成“#VALUE!”错
有没有办法检查是否没有 AIO 写入给定文件?我在我的 Unix 类(class)上制作了一个项目,该项目将是一个上下文无关(基于 UDP)的国际象棋服务器,并且所有数据都必须存储在文件中。应用程序将
我有一个如下所示的函数: public Status execute() { Status status = doSomething(); if (status != Stat
我正在使用 Composer,我不希望 PhpStorm 在 vendor 文件夹上运行任何错误检查或检查,因为它对 vendor/中的某些代码显示误报composer/autoload_static
Chapel 的一个很好的特性是它区分了数组的域和它的分布。检查两个数组是否具有相同的域和分布(通常想要的)的最佳方法是什么? 我能看到的最好的方法是检查 D1==D2和 D1.dist==D2.di
在我的 JavaScript 函数中,我为所有输入、文本区域和选择字段提供实际值作为 initial_value: $('input, textarea, select').each(function
我正在编写一个分解为几个简单函数的 PHP 类。在构造函数中,它调用另一个名为 processFile 的函数。该函数调用 5 个私有(private)函数并进行检查。如果检查失败,它会将消息分配给
这个问题已经有答案了: How to detect if user it trying to open a link in a new tab? (2 个回答) 已关闭 7 年前。 我认为 JavaS
我正在浏览我们的代码库并看到很多这样的测试: declare @row_id int = ... declare @row_attribute string select @row_attribu
我正在声明一个用作比较的函数。我的问题是: 为什么条件充当语句? 为什么第 4 行可以工作,而第 5 行却不行? 我知道这段代码不切实际且未使用,但为什么编译器允许这种语法? 谷歌没有找到答案。但话又
到目前为止,我有一个带有空文本字段的 PHP Kontaktform,并使用以下命令检查了所需的字段: $name = check_input($_POST['name'], "请输入姓名。"); 现
目前,我能想到的合理检查的唯一方法没有臃肿的逻辑: if ( $value > 0 ) { // Okay } else { // Not Okay } 有没有更好的办法? 最佳答案
我正在尝试运行一个脚本,如果 i 存在(意味着存在 i 值,任何值)或其他部分,我希望运行其中的一部分如果i没有值就运行,有人可以启发我吗? 我说的是 for 循环,比如 for (var i=0;
我是一名优秀的程序员,十分优秀!