


Menghidu penyemak imbas tidak lagi disyorkan, tetapi ia masih diperlukan dalam beberapa situasi. Sebagai contoh, beberapa skrip statistik. Dalam pelayar standard, document.implementation.hasfeature disediakan, tetapi ia adalah buggy dan tidak tepat Pada masa ini, w3c telah melancarkan kaedah CSS.supports, yang menunjukkan perhatian semua orang kepada aspek ini.
1. Tentukan penyemak imbas.
Pelayar arus perdana termasuk iaitu firefox opera chorme safari Pada masa awal, rangka kerja ini dinilai melalui navigator.userAgent Pada masa ini, hampir semua pelayar asing boleh menilai.
Mengenai skrip pertimbangan penyemak imbas, jQuery telah dialihkan keluar daripada ontologi dan dibentuk menjadi pemalam. Terdapat lebih banyak cara untuk memperkenalkan,
Untuk penentuan peranti mudah alih yang berkaitan, adalah disyorkan untuk melihat kod sumber mudah alih jQuery dan zepto.
isIPone = /isIPone/i.test(navigator.userAgent);
isIPone4 = window.devicePixelRatio >= 2 //Dalam halaman web, nisbah piksel ke titik dipanggil peranti-pixel-nisbah Peranti biasa ialah 1, iPhone4 ialah 2 dan beberapa model Android ialah 1.5
. isIpad = /ipad/i.test(navigator.userAgent)
isAndroid = /android/i.test(navigator.userAgent)
isIOS = isIPone ||. isIpad
Untuk penyemak imbas domestik, anda boleh melihat Tangrame atau qwrap, yang pada asasnya ialah IE, webkit dan kernel blink.
2. Pengesanan sokongan acara
Kangax, ahli teras prototaip, menulis artikel untuk menentukan sokongan penyemak imbas untuk acara tertentu. Pelaksanaan yang diberikan di sana adalah seperti berikut:
var isEventSupported = (function() { var TAGNAMES = { 'select':'input','change':'input', 'submit':'form','reset':'form', 'error':'img','load':'img','abort':'img' } function isEventSupported(eventName){ var el = document.createElement(TAGNAMES[eventName] || 'div'); eventName = 'on' + eventName; var isSupported = (eventName in el); if (!isSupported) { el.setAttribute(eventName, 'return;'); isSupported = typeof el[eventName] == 'function'; } el = null; return isSupported; } return isEventSupported; })();
Kini jQuery dan rangka kerja lain menggunakan versi skrip yang dipermudahkan
Tetapi mana-mana yang lebih baik, pengesanan ini hanya berfungsi untuk DOM0. Contohnya, DOMMouseScroll DOMContentLoaded DOMFocusIn DOMFocusOut DOMSubtreeModified DOMNodeInserted DOMNodeRemoved DOMNodeRemovedFromDocument DOMNodeInserted DOMNodeInsertedItrDoMCOutDoM, DOMAModModModified DOMNodeRemoved. tak guna.
Sesetengah acara ini sangat berguna, seperti DOMMouseScroll Firefox tidak menyokong tetikus dan hanya boleh menggunakannya sebagai pengganti.
DOMContentLoaded ialah peristiwa penting dalam melaksanakan domReady; DOMNodeRemoved digunakan untuk menentukan sama ada elemen dialih keluar daripada nod induknya, yang mungkin merupakan nod elemen lain atau serpihan dokumen dialihkan daripada pepohon DOM dan DOMAttrModified sering digunakan untuk mensimulasikan; onpropertyChange IE
CSS3 menambah dua animasi, satu animasi peralihan dan satu lagi animasi tweening bingkai utama. Mereka semua menggunakan panggilan balik acara pada akhir acara. Tetapi semasa proses penyeragaman, nama yang diberikan pelayar kepada mereka hampir rawak. Ini juga perlu dikesan lebih awal.
Berikut ialah pelaksanaan bootstrap. Saya dengar ia datang dari modernizr, yang agak kasar. Contohnya, Oprera yang anda gunakan sudah pun menyokong nama acara standard tanpa acara. Ia masih mengembalikan oTransitionEnd.
$.supports.transition = (function(){ var transitionEnd = (function(){ var el = document.createElement('bootstarp'), transEndEventNames = { 'WebkitTransition':'webkitTransitionEnd', 'MozTransition':'transitionend', 'OTransition':'OTransitionEnd otransitionend', 'transition':'transitionend' }; for (var name in transEndEventNames){ if (el.style[name] !== undefined){ return transEndEventNames[name] } } }()); return transitionEnd && { end: transitionEnd } })();
animasi tween bingkai utama berasal daripada modul fx_neo massa
var eventName = { AnimationEvent:'animationend', WebKirAnimationEvent: 'WebKirAnimationEnd' },animationend; for(var name in eventName) { if (/object|function/.test(typeof window[name])){ animationend = eventName[name] break } }
3. Detektif sokongan gaya
css3 membawa banyak gaya yang berguna, tetapi masalahnya ialah setiap penyemak imbas mempunyai awalan peribadinya sendiri menyediakan kaedah cssName untuk mengendalikannya, ia akan mengembalikan nama gaya kes unta yang tersedia, jika tidak, ia akan jadi batal
var prefixes = ['','-webkit-','-o-','-moz-','-ms-']; var cssMap = { "float" : $.support.cssFloat ? 'cssFloat' : 'styleFloat',background:'backgroundColor' }; function cssName(name, host, camelCase){ if(cssMap[name]) { return cssMap[name]; } host = host || document.documentElement for (var i = 0 || n = prefixes.length; i < n; i++) { camelCase = $.String.camelize(prefixes[i] + name); if (camelCase in host) { return (cssMap[name] = camelCase) } } return null }
一个样式对于N种样式值,比如display有n种取值,如果要侦测浏览器是否支持某一种,会很麻烦。为此,浏览器做了一个善举,给出一个css.supports的API,如果不支持,则尝试下一个开源项目。显然,不是很完美。
https://github.com/termi/CSS.supports
4.jQuery的一些常用的特征的含义
jQuery在support模块例举了一些常用的DOM特征支持情况,不过名字起的很怪,不同版本差别也很大,本章以jQuery1.8为准。
leadingWhitespace:判定浏览器在进行innerHTML赋值时,是否存在trimLeft操作,这个功能原本是IE发明的,结果其他浏览器认为要忠于以后的原始值,最前面的空白不能神略掉,要变成一个文本节点,最终IE678返回false,其他浏览器返回true
tobody:指在用innerHTML动态创建元素时,浏览器是否会在table内自动补上tobody,jQuery希望浏览器别处理,让jQuery来补全。判断浏览器是否只能插入tobody。在表格布局的年代,这个特性十分受用。如果没有tbody,table会在浏览器解析到闭合标签时才显示出来。如果起始标签和闭合标签相隔很远,换言之,这个表格很长,用户会什么都看不到,但有了tbody分段显示和识别,避免了长时间空白后一下子显示出来的情况。
var div = document.createElement("div");
div.innerHTML = '
alert(div.innerHTML) //=>ie678返回
html.Serialize:判断浏览器是否完好支持用innerHTML转换一个符合html标签规则的字符串为一个元素节点,此过程jQuery称为序列化,但IE支持不够完好。包括scirpt link style mata在内的no-scope元素都转换失败。
style:这个命名很难看懂,不看代码不知道什么意思,真像是判定getAttribute是否返回style的用户预设值。IE678没有返回区分特性的特征,返回一个CSSStyleDeclaration对象。
hrefNormalized:判定getAttribute能否返回href的用户预设值。IE会补充给你完整的路径给你
opacity:判定浏览器是否支持opacity属性,ie678要使用滤镜
cssFloat: 判定float的样式在DOM的名字是那个,W3c为cssFloat,IE678为styleFloat
CheckOn: 在大多数浏览器中checkBox的value为on,chorme返回空字符串
optSelected: 判定是否正确取得动态添加option元素的seleted,ie6-10与老版的safari对动态添加option没有设置为true。解决办法,在访问selected属性前,先访问父节点的selectedIndex属性,再强制计算option的seleted.
<select id='optSelected'></select> <script type="text/javascript"> var select = document.getElementById('optSelected'); var option = document.createElement('option'); select.appendChild(option); alert(option.selected); select.selectedIndex; alert(option.selected) </script>
optDisabled: Tentukan sama ada atribut disable elemen pilih mempengaruhi nilai disabled elemen child Dalam Safari, sebaik sahaja elemen pilih dilumpuhkan, elemen anaknya juga dilumpuhkan, mengakibatkan nilai yang tidak boleh diperolehi
checkClone: merujuk kepada elemen kotak semak Jika checked=true ditetapkan, dan selepas berbilang klon, bolehkah salinannya kekal benar. Kaedah ini hanya mengembalikan palsu dalam safari4, yang lain adalah benarinlineBlockNeedsLayout: Tentukan sama ada hendak menggunakan kaedah hasLayout untuk menjadikan display:inline-block berkesan. Kaedah ini hanya benar untuk ie678
getSetAttribute: Tentukan sama ada untuk membezakan atribut ciri, hanya ie678 adalah palsu
noCloneEvent: Menentukan sama ada hendak mengklon acara pengikatan attachEvent semasa mengklon elemen. Hanya versi lama IE dan mod keserasiannya yang mengembalikan palsu
enctype: Tentukan sama ada penyemak imbas menyokong atribut pengekodan IE67 sebaliknya menggunakan atribut pengekodan
boxModel: Tentukan sama ada penyemak imbas berada dalam mod pemaparan kotak kandungan
submitBubbles, changeBubbles, focusinBubble: Tentukan sama ada penyemak imbas menyokong acara ini dan menggelembungkan ke dokumen
shrinkWrapBlocks: Tentukan sama ada elemen akan diregangkan oleh elemen kanak-kanak. Dalam IE678, elemen yang tidak diganti akan mengembangkan elemen induknya apabila saiz dan hasLayout ditetapkan.
html5Clone: Tentukan sama ada cloneNode boleh digunakan untuk mengklonkan teg baharu HTML5 versi lama IE tidak menyokongnya. Perlu menggunakan outerHTML
deleteExpando: Menentukan sama ada elemen tersuai pada nod elemen boleh dipadamkan Ini digunakan dalam sistem caching jQuery. Versi lama IE tidak menyokongnya dan langsung tidak ditentukan
PixelPosition: Tentukan sama ada getComputedStyle boleh menukar nilai peratusan unsur kiri atas sebelah kanan bawah. Ini akan menyebabkan masalah dalam sistem webkit, dan anda perlu menggunakan hack Dean Edwards
reliableMarginRight: Tentukan sama ada getComputedStyle boleh mendapatkan marginRiht elemen dengan betul.
clearCloneStyle: Pepijat pelik akan muncul dalam ie9 10. Apabila elemen gaya latar-* elemen disalin dan elemen yang disalin dikosongkan, gaya asal akan dikosongkan.
Dengan kemas kini gila pelayar, pelbagai pepijat yang disebabkan oleh penyemak imbas standard telah mengatasi IE, dan pengesanan ciri menjadi semakin penting.
Di atas adalah keseluruhan kandungan artikel ini, saya harap anda semua menyukainya.

去掉重复并排序的方法:1、使用“Array.from(new Set(arr))”或者“[…new Set(arr)]”语句,去掉数组中的重复元素,返回去重后的新数组;2、利用sort()对去重数组进行排序,语法“去重数组.sort()”。

本篇文章给大家带来了关于JavaScript的相关知识,其中主要介绍了关于Symbol类型、隐藏属性及全局注册表的相关问题,包括了Symbol类型的描述、Symbol不会隐式转字符串等问题,下面一起来看一下,希望对大家有帮助。

怎么制作文字轮播与图片轮播?大家第一想到的是不是利用js,其实利用纯CSS也能实现文字轮播与图片轮播,下面来看看实现方法,希望对大家有所帮助!

本篇文章给大家带来了关于JavaScript的相关知识,其中主要介绍了关于对象的构造函数和new操作符,构造函数是所有对象的成员方法中,最早被调用的那个,下面一起来看一下吧,希望对大家有帮助。

本篇文章给大家带来了关于JavaScript的相关知识,其中主要介绍了关于面向对象的相关问题,包括了属性描述符、数据描述符、存取描述符等等内容,下面一起来看一下,希望对大家有帮助。

方法:1、利用“点击元素对象.unbind("click");”方法,该方法可以移除被选元素的事件处理程序;2、利用“点击元素对象.off("click");”方法,该方法可以移除通过on()方法添加的事件处理程序。

foreach不是es6的方法。foreach是es3中一个遍历数组的方法,可以调用数组的每个元素,并将元素传给回调函数进行处理,语法“array.forEach(function(当前元素,索引,数组){...})”;该方法不处理空数组。

本篇文章给大家带来了关于JavaScript的相关知识,其中主要介绍了关于BOM操作的相关问题,包括了window对象的常见事件、JavaScript执行机制等等相关内容,下面一起来看一下,希望对大家有帮助。


Alat AI Hot

Undresser.AI Undress
Apl berkuasa AI untuk mencipta foto bogel yang realistik

AI Clothes Remover
Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

Undress AI Tool
Gambar buka pakaian secara percuma

Clothoff.io
Penyingkiran pakaian AI

AI Hentai Generator
Menjana ai hentai secara percuma.

Artikel Panas

Alat panas

EditPlus versi Cina retak
Saiz kecil, penyerlahan sintaks, tidak menyokong fungsi gesaan kod

Pelayar Peperiksaan Selamat
Pelayar Peperiksaan Selamat ialah persekitaran pelayar selamat untuk mengambil peperiksaan dalam talian dengan selamat. Perisian ini menukar mana-mana komputer menjadi stesen kerja yang selamat. Ia mengawal akses kepada mana-mana utiliti dan menghalang pelajar daripada menggunakan sumber yang tidak dibenarkan.

mPDF
mPDF ialah perpustakaan PHP yang boleh menjana fail PDF daripada HTML yang dikodkan UTF-8. Pengarang asal, Ian Back, menulis mPDF untuk mengeluarkan fail PDF "dengan cepat" dari tapak webnya dan mengendalikan bahasa yang berbeza. Ia lebih perlahan dan menghasilkan fail yang lebih besar apabila menggunakan fon Unicode daripada skrip asal seperti HTML2FPDF, tetapi menyokong gaya CSS dsb. dan mempunyai banyak peningkatan. Menyokong hampir semua bahasa, termasuk RTL (Arab dan Ibrani) dan CJK (Cina, Jepun dan Korea). Menyokong elemen peringkat blok bersarang (seperti P, DIV),

SublimeText3 versi Mac
Perisian penyuntingan kod peringkat Tuhan (SublimeText3)

MantisBT
Mantis ialah alat pengesan kecacatan berasaskan web yang mudah digunakan yang direka untuk membantu dalam pengesanan kecacatan produk. Ia memerlukan PHP, MySQL dan pelayan web. Lihat perkhidmatan demo dan pengehosan kami.