λ€μ΄κ°λ©°
μ§ννλ λ―Έλ νλ‘μ νΈμΈ κ°μλ°μ보 κ²μμμ κ²μμμ νμ΄μ§λ‘ λμ΄κ°λ©΄ 3μ΄ μΉ΄μ΄νΈκ° μμλλ€.
κ·Έλ°λ° μ¬ν리 λΈλΌμ°μ μ iOS λλ°μ΄μ€λ€μμλ Audio.play ν¨μκ° λμνμ§ μλ κ²μ μκ² λμλ€. π±
ν¬λ‘¬κ³Ό λΉμ·νκ² λΈλΌμ°μ μ μ±
μ μ¬μ΄λ μλμ¬μμ΄ λ°λ‘ λμ§ μλλ‘ λ§νμλ κ²!...
κ·Έλ λ€λ©΄ μ²μ μΈνΈλ‘νμ΄μ§μμ λ²νΌμ λλ μ λ λ°°κ²½μμ
μ΄ λμ€λλ‘ νλ κ²μ²λΌ,
μ¬κΈ°μλ 무μΈκ° λλ μ λ κ²μμ΄ μμλ μ μλλ‘ ν΄μΌνλλ°... (setTimout λ©μλλ μ μμ μΌλ‘ λμνμ§ μμλ€.)
μ¬μ©μ± λΆλΆμμλ μ‘°κΈ λ¨μ΄μ§ μ μμ§λ§, iOSμ μ¬ν리 μ μ©μΌλ‘ κ²μ μμμ μ리λ λ μ΄μ΄λ₯Ό κΉμμ£ΌκΈ°λ‘ νλ€.
κ·ΈλΌ λ¨Όμ νμ¬ μ μνκ³ μλ λΈλΌμ°μ κ° λ¬΄μμΈμ§λ₯Ό μμ보λ κ²μ΄ μ°μ !
navigator κ°μ²΄
navigator κ°μ²΄λ λΈλΌμ°μ μ λν λ€μν μ 보λ₯Ό μ μ₯νλ κ°μ²΄μ΄λ€. (λΈλΌμ°μ 곡κΈμ, λ²μ μ 보 μΈ..)
λΈλΌμ°μ μ κΈ°λ³Έ μΈμ΄, μ€νλκ³ μλ μ΄μ체μ λ± μ¬λ¬ κ°μ§λ₯Ό μ μ μλ€!
λΈλΌμ°μ νμ νμΈ
μ΄ navigator κ°μ²΄μ μμ± μ€ νλμΈ userAgentλ₯Ό ν΅ν΄μ νμ¬ μ μνκ³ μλ λΈλΌμ°μ μ μ’
λ₯λ₯Ό μ μ μλ€.
νμ§λ§ λ§μ λΈλΌμ°μ λ³λ‘ μΆλ ₯ν΄λ³΄λ©΄ κ²°κ³Όκ° λΉμ·λΉμ·ν κ²μ μ μ μλλ°..
- ν¬λ‘¬
- μ¬ν리
μ΄λ λλΆλΆμ λΈλΌμ°μ λ€μ΄ mozlia λ λλ§μ λ°λ₯΄κΈ° λλ¬Έμ, λΈλΌμ°μ λ λλ§ μμ§ κΈ°μ μ 곡μ νκ³ μκΈ° λλ¬Έμ΄λΌκ³ νλ€.
κ·Έλμ μ’ λ μΈλΆμ μΌλ‘ μλμ κ°μ΄ ν¨μλ₯Ό μμ±νλ©΄ μ’ λ λͺ ννκ² λΈλΌμ°μ νμ μ 리ν΄ν μ μλ€.
function checkBrowser() {
const agent = navigator.userAgent.toLowerCase();
if (agent.indexOf('chrome') != -1) return 'Chrome';
if (agent.indexOf('opera') != -1) return 'Opera';
if (agent.indexOf('firefox') != -1) return 'Firefox';
if (agent.indexOf('safari') != -1) return 'Safari';
if (agent.indexOf('mozilla/5.0') != -1) return 'Mozilla';
}
μ μ©ν μ½λλ₯Ό 보면, κ°μ Έμ¨ λΈλΌμ°μ νμ μμ μ¬νλ¦¬μΌ κ²½μ°μλ§ λ³λμ μ΄λ²€νΈλ¦¬μ€λλ₯Ό μΆκ°ν΄μ£Όμλ€.
const browser = checkBrowser();
function startGameOnSafari() {
playing();
startTimerLayer.classList.toggle('is-active');
}
function startGame() {
if (browser === 'Safari') {
startTimerLayer.addEventListener('click', startGameOnSafari);
} else {
playing();
}
}
window.addEventListener('load', startGame);
μ¬ν리μμλ§ μ μ©λλ SCSS μ½λ
μ¬ν리μμλ§ μ μ©λλ SCSSλ₯Ό μν΄μλ μ½κ°μ κΌΌμκ° νμνλ€.
λΈλΌμ°μ μμ -webkit-appearance: none
μ μ§μν λ μ μ©λλ μ½λ.
@media not all and (min-resolution: 0.001dpcm) {
@supports (-webkit-appearance: none) {
@content;
}
}
λμ κ²½μ°λ is-safari λΌλ ν΄λμ€λ₯Ό ν΅ν΄ μ¬ν리μμλ§ λ³΄μ¬μ§ μ μλλ‘ νλ€.
@media not all and (min-resolution: 0.001dpcm) {
@supports (-webkit-appearance: none) {
&.safari-only {
display: block;
}
&.safari-only.is-active {
display: none;
opacity: 0;
}
}
}
κ·ΈλΌ μ΄λ κ², μ¬ν리 λΈλΌμ°μ μμλ§ LET'S GO! λΌλ ν μ€νΈ μμμ΄ λ¨Όμ λμ€κ³ μ΄λ₯Ό λλ μ λ μΉ΄μ΄νΈκ° μμλλ€!
'π Retrospect > Personal Projects' μΉ΄ν κ³ λ¦¬μ λ€λ₯Έ κΈ
μλ¬ μμ μ½μ§ κΈ°λ‘ (1) (0) | 2022.09.14 |
---|---|
κ°μλ°μ보 λ―Έλκ²μμ λ§λ€μ΄λ³΄λ©° (0) | 2022.06.27 |
[JSTL] ftm νκ·Έλ‘ κΈμ‘ μΌν νμ (0) | 2021.09.27 |
[JS] μΉ΄μΉ΄μ€ μ’ν>μ£Όμλ³ν API μ¬μ© (0) | 2021.09.27 |
[JS] URL ν΄λ¦½λ³΄λμ 볡μ¬νκΈ° (0) | 2021.09.15 |
Comment