Jak uzyskać dostęp do kontaktów z książki adresowej

Czasami chcesz zezwolić użytkownikom aplikacji na wybranie jednego z kontaktów, z którym będą mogli wysłać wiadomość przez e-maila lub aplikację czatu, albo pomóc im w znalezieniu kontaktów, które już dołączyły do sieci społecznościowej.

Nowoczesny sposób

Korzystanie z interfejsu Contact Picker API

Aby pobrać kontakty z książki adresowej, musisz użyć interfejsu Contact Picker API, który pozwala użytkownikom wybierać wpisy z listy kontaktów i udostępniać ich niektóre szczegóły aplikacji. Dostępnych jest kilka właściwości, takich jak name, email, tel, address i icon. Aby dowiedzieć się więcej o konkretnych obsługiwanych właściwościach, wywołaj navigator.contacts.getProperties(). Aby umożliwić użytkownikowi wybranie wielu kontaktów, przekaż {multiple: true} jako drugi parametr funkcji navigator.contacts.select().

Obsługa przeglądarek

  • x
  • x
  • x
  • x

Źródło

Interfejs Contact Picker API jest dostępny w Chrome od wersji 80 na Androida.

Klasyczny sposób

Używanie zwykłego formularza

Metoda zastępcza polega na użyciu zwykłego formularza, w którym użytkownik może wpisać szczegóły kontaktu.

Obsługa przeglądarek

  • 1
  • 12
  • 1
  • ≤4

Źródło

Stopniowe ulepszanie

Jeśli interfejs Contact Picker API jest obsługiwany, ukryj statyczne pola formularzy i wyświetlaj przycisk selektora.

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}`;
    }
  });
}

Więcej informacji

Pokaz

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 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>

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;
}
        

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}`
    }
  });
}