2

リンクをクリックして電話番号に電話をかけたいのですが、電話から連絡先を取得する必要があります。そこで、このためのコードを実装しました。しかし、電話はダイヤラーを開いていますが、取得した連絡先番号がありません。なにか提案を?

<!DOCTYPE html>
<html>
  <head>
    <title>Contact Example</title>
    <script type="text/javascript" charset="utf-8" src="cordova-1.8.0.js"></script>
    <meta name="viewport" content="width=device-width, initial-scale=1"> 
    <link rel="stylesheet" href="jquery.mobile-1.1.0.min.css" />
    <script src="jquery-1.7.1.min.js"></script>
    <script src="jquery.mobile-1.1.0.min.js"></script>
    <script type="text/javascript" charset="utf-8">

    // Wait for Cordova to load
    //
    document.addEventListener("deviceready", onDeviceReady, false);

    // Cordova is ready
    //
    function onDeviceReady() {
        // specify contact search criteria
        var options = new ContactFindOptions();
        options.filter="";          // empty search string returns all contacts
        options.multiple=true;      // return multiple results
        filter = ["displayName"];   // return contact.displayName field

        // find contacts
        navigator.contacts.find(filter, onSuccess, onError, options);
    }

    // onSuccess: Get a snapshot of the current contacts
    //
    function onSuccess(contacts) {
        for (var i=0; i<contacts.length; i++) {
            alert(contacts[i].displayName);
            var phonenumber;
            phonenumber = contacts[i].phoneNumbers;
            $("ul").append("<li><a href=tel:"+phonenumber+">"+contacts[i].displayName+"</a></li>");
        }
    };

    // onError: Failed to get the contacts
    //
    function onError(contactError) {
        alert('onError!');
    }

    </script>
  </head>
  <body>
    <ul data-role="listview" data-theme="g" data-filter="true">
        <li><a>hello</a></li>
    </ul>
  </body>
</html>
4

3 に答える 3

4

contacts[i].phoneNumbersは配列なので、変数に追加する必要があります。

var phonenumber = contacts[i].phoneNumbers[0];

または、その配列をループして、最も適した方を選択します。

于 2012-06-12T10:47:57.890 に答える
1

試してみてください

$("ul").append("<li><a href=callto:"+phonenumber+">"+contacts[i].displayName+"</a></li>");
于 2012-06-12T09:39:32.057 に答える
0

これは私のために働いた:

phonenumber = contacts[i].phoneNumbers[0].value.replace(" ", "");

$("#ul").append("<li><a href=tel:+91"+phonenumber.replace(" ", "")+">"+contacts[i].displayName+"<br/>"+phonenumber.replace(" ", "")+"</a></li><br/>");

電話番号の数字の間にスペースが入っているため、replace() 関数を使用しました。

それがあなたを助けることを願っています。

于 2014-04-29T06:49:55.647 に答える