我的表格只会发送到10位美国数字。选择国家/地区后,我想发送给国际号码。浏览Intl-Tel-Input文档后,可能需要以下代码,但我没有运气:myInput.val(myInput.intlTelInput("getNumber"));
这是Branch.io text me the app文档,主要是下面的代码,其中包含使用phoneSMS
的更新。
如何使用branch.io和Intl-Tel-Input发送至国际号码?
<script type="text/javascript">
(function(b,r,a,n,c,h,_,s,d,k){if(!b[n]||!b[n]._q){for(;s<_.length;)c(h,_[s++]);d=r.createElement(a);d.async=1;d.src="https://cdn.branch.io/branch-latest.min.js";k=r.getElementsByTagName(a)[0];k.parentNode.insertBefore(d,k);b[n]=h}})(window,document,"script","branch",function(b,r){b[r]=function(){b._q.push([r,arguments])}},{_q:[],_v:1},"addListener applyCode banner closeBanner creditHistory credits data deepview deepviewCta first getCode init link logout redeem referrals removeListener sendSMS setIdentity track validateCode".split(" "), 0);
branch.init('YOUR-BRANCH-KEY');
function sendSMS(form) {
var phone = form.phoneSMS.value;
var linkData = {
tags: [],
channel: 'Website',
feature: 'TextMeTheApp',
data: {
'foo': 'bar'
}
};
var options = {};
var callback = function(err, result) {
if (err) {
alert("Sorry, something went wrong.");
}
else {
alert("SMS sent!");
}
};
branch.sendSMS(phone, linkData, options, callback);
form.phone.value = "";
}
</script>
的HTML
<form onsubmit="sendSMS(this); return false;">
<input type="tel" name="phoneSMS" id="phoneSMS">
<input type="submit"/>
</form>
国际电话输入插件:
<script type="text/javascript" src="{{ site.baseurl }}js/intlTelInput.js"></script>
<script>
$("#phoneSMS").intlTelInput({
utilsScript: "{{ site.baseurl }}/js/utils.js"
});
</script>
最佳答案
可以在数字前加上国际前缀的最简单方法是在var phone = form.phoneSMS.value
函数中代替sendSMS()
来更新它,以要求intlTelInput本身输入数字-它为您提供国际格式。
例:
var phone = $('#phoneSMS').intlTelInput("getNumber")
有关更多参考,请查看intlTelInput的公共方法。
关于javascript - SMS没有使用Branch.io和intl-tel-input发送到国际号码,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/37057985/