Skip to main content

How to access contacts from the address book






                HTML  

How to access contacts from the address book


<!DOCTYPE html> <html lang="en"> <head> <meta charset="utf-8" /> <meta name="viewport" content="width=device-width, initial-scale=1" /> <link rel="icon" href="data:image/svg+xml,<svg xmlns=%22http://www.w3.org/2000/svg%22 viewBox=%220 0 100 100%22><text y=%22.9em%22 font-size=%2290%22>🎉</text></svg>" /> <title>How to access contacts from the address book</title> </head> <body> <h1>How to access contacts from the address book</h1> <p>Ship your order as a present to a friend.</p> <button hidden type="button">Open address book</button> <pre></pre> <label> Name <input class="name" autocomplete="name"></label> <label hidden>Address <input class="address" required></label> <label>Street <input class="autofill" autocomplete="address-line1" required></label> <label>City <input class="autofill" autocomplete="address-level2" required></label> <label>State / Province / Region (optional) <input class="autofill" autocomplete="address-level1"></label> <label>ZIP / Postal code (optional) <input class="autofill" autocomplete="postal-code"></label> <label>Country <input class="autofill" autocomplete="country"></label> <label>Email<input class="email" autocomplete="email"></label> <label>Telephone<input class="tel" autocomplete="tel"></label> </body> </html>


        JS

const button = document.querySelector('button'); const name = document.querySelector('.name') const address = document.querySelector('.address') const email = document.querySelector('.email') const tel = document.querySelector('.tel') const pre = document.querySelector('pre') const autofills = document.querySelectorAll('.autofill') if ('contacts' in navigator) { button.hidden = false; for (const autofill of autofills) { autofill.parentElement.style.display = 'none' } address.parentElement.style.display = 'block'; button.addEventListener('click', async () => { const props = ['name', 'email', 'tel', 'address']; const opts = {multiple: false}; try { const [contact] = await navigator.contacts.select(props, opts); name.value = contact.name; address.value = contact.address; tel.value = contact.tel email.value = contact.email; } catch (err) { pre.textContent = `${err.name}: ${err.message}` } }); }

            
                                    CSS

html { box-sizing: border-box; font-family: system-ui, sans-serif; color-scheme: dark light; } *, *:before, *:after { box-sizing: inherit; } body { margin: 1rem; } input { display: block; margin-block-end: 1rem; }

Comments

Popular posts from this blog

HOW TO CREATE COPY BUTTON WITH HTML, CSS AND JS LANGUAGE

                                                                                                                                                      STRUCTURE WITH  <HTML> <! DOCTYPE html > < html lang = " en " > < head > < meta charset = " utf-8 " /> < meta name = " viewport " content = " width=device-width, initial-scale=1 " /> < link rel = " icon " href = " data:image/svg+xml,<svg xmlns=%22http://www.w3.org/2000/svg%22 viewBox=%220 0 100 100%22><text...

HOW TO CREATE A REGISTRATION FORM WITH < HYPER TEXT MARKUP LANGUAGE >

                                                                          CODES <HTML>   <! DOCTYPE html > < html lang = "en" >   < head >     < meta charset = "utf-8" />     < meta name = "viewport" content = "width=device-width, initial-scale=1" />     < link       rel = "icon"       href = "data:image/svg+xml, < svg xmlns=%22http://www.w3.org/2000/svg%22 viewBox=%220 0 100 100%22> < text y=%22.9em%22 font-size=%2290%22>🎉 < /text> < /svg>"     />     < title > How to access contacts from the address book </ title >   </ head >   < body >     < h1 > How to acc...

HOW TO CREATE BUTTONS WITH HTML AND CSS

  CUSTOM BUTTON WITH HTML < section > < h2 > 9 button types </ h2 > < p > Unified modern style, visual differences reinforce purpose. </ p > </ section > < button > Default </ button > < input type = " button " value = " <input> " /> < button > < svg viewBox = " 0 0 24 24 " stroke = " currentColor " width = " 24 " height = " 24 " aria-hidden = " true " > < path d = " M3 8l7.89 5.26a2 2 0 002.22 0L21 8M5 19h14a2 2 0 002-2V7a2 2 0 00-2-2H5a2 2 0 00-2 2v10a2 2 0 002 2z " /> </ svg > Icon </ button > < button type = " submit " > Submit </ button > < button type = " button " > Type Button </ button > < button type = " reset " > Reset </ button > < button disabled > Disabled </ button > < button class ...