应项目需求,需要满足海外用户也可方便注册成为公司会员。调研之后,决定注册界面应该包括以下两部分
一定是 2 个输入框。
- 国家码。推荐使用下拉框
- 手机号码。根据选中的国家码,做有效性校验。
<1>国家码,目前采用的国际通用的ISO标准,具体世界各国的国家码对应国家的SQL如下
SET FOREIGN_KEY_CHECKS=0;
-- ----------------------------
-- Table structure for `sms_country`
-- ----------------------------
DROP TABLE IF EXISTS `sms_country`;
CREATE TABLE `sms_country` (
`id` int(11) NOT NULL AUTO_INCREMENT,
`iso` char(2) NOT NULL,
`iso3` char(3) DEFAULT NULL,
`name` varchar(80) NOT NULL,
`name_zh` varchar(80) DEFAULT NULL,
`nicename` varchar(80) NOT NULL,
`numcode` smallint(6) DEFAULT NULL,
`phonecode` int(5) NOT NULL,
PRIMARY KEY (`id`)
) ENGINE=InnoDB AUTO_INCREMENT=240 DEFAULT CHARSET=utf8;
-- ----------------------------
-- Records of sms_country
-- ----------------------------
INSERT INTO `sms_country` VALUES ('1', 'AF', 'AFG', 'AFGHANISTAN', '阿富汗', 'Afghanistan', '4', '93'),
('2', 'AL', 'ALB', 'ALBANIA', '阿尔巴尼亚', 'Albania', '8', '355'),
('3', 'DZ', 'DZA', 'ALGERIA', '阿尔及利亚', 'Algeria', '12', '213'),
('4', 'AS', 'ASM', 'AMERICAN SAMOA', '美属萨摩亚', 'American Samoa', '16', '1684'),
('5', 'AD', 'AND', 'ANDORRA', '安道尔', 'Andorra', '20', '376'),
('6', 'AO', 'AGO', 'ANGOLA', '安哥拉', 'Angola', '24', '244'),
('7', 'AI', 'AIA', 'ANGUILLA', '安圭拉岛', 'Anguilla', '660', '1264'),
('8', 'AQ', null, 'ANTARCTICA', '南极洲', 'Antarctica', null, '0'),
('9', 'AG', 'ATG', 'ANTIGUA AND BARBUDA', '安提瓜岛和巴布达', 'Antigua and Barbuda', '28', '1268'),
('10', 'AR', 'ARG', 'ARGENTINA', '阿根廷', 'Argentina', '32', '54'),
('11', 'AM', 'ARM', 'ARMENIA', '亚美尼亚', 'Armenia', '51', '374'),
('12', 'AW', 'ABW', 'ARUBA', '阿鲁巴岛', 'Aruba', '533', '297'),
('13', 'AU', 'AUS', 'AUSTRALIA', '澳大利亚', 'Australia', '36', '61'),
('14', 'AT', 'AUT', 'AUSTRIA', '奥地利', 'Austria', '40', '43'),
('15', 'AZ', 'AZE', 'AZERBAIJAN', '阿塞拜疆', 'Azerbaijan', '31', '994'),
('16', 'BS', 'BHS', 'BAHAMAS', '巴哈马群岛', 'Bahamas', '44', '1242'),
('17', 'BH', 'BHR', 'BAHRAIN', '巴林', 'Bahrain', '48', '973'),
('18', 'BD', 'BGD', 'BANGLADESH', '孟加拉国', 'Bangladesh', '50', '880'),
('19', 'BB', 'BRB', 'BARBADOS', '巴巴多斯', 'Barbados', '52', '1246'),
('20', 'BY', 'BLR', 'BELARUS', '白俄罗斯', 'Belarus', '112', '375'),
('21', 'BE', 'BEL', 'BELGIUM', '比利时', 'Belgium', '56', '32'),
('22', 'BZ', 'BLZ', 'BELIZE', '伯利兹', 'Belize', '84', '501'),
('23', 'BJ', 'BEN', 'BENIN', '贝宁', 'Benin', '204', '229'),
('24', 'BM', 'BMU', 'BERMUDA', '百慕大', 'Bermuda', '60', '1441'),
('25', 'BT', 'BTN', 'BHUTAN', '不丹', 'Bhutan', '64', '975'),
('26', 'BO', 'BOL', 'BOLIVIA', '玻利维亚', 'Bolivia', '68', '591'),
('27', 'BA', 'BIH', 'BOSNIA AND HERZEGOVINA', '波斯尼亚和黑塞哥维那', 'Bosnia and Herzegovina', '70', '387'),
('28', 'BW', 'BWA', 'BOTSWANA', '博茨瓦纳', 'Botswana', '72', '267'),
('29', 'BV', null, 'BOUVET ISLAND', '布维岛', 'Bouvet Island', null, '0'),
('30', 'BR', 'BRA', 'BRAZIL', '巴西', 'Brazil', '76', '55'),
('31', 'IO', null, 'BRITISH INDIAN OCEAN TERRITORY', '英属印度洋领地', 'British Indian Ocean Territory', null, '246'),
('32', 'BN', 'BRN', 'BRUNEI DARUSSALAM', '文莱达鲁萨兰国', 'Brunei Darussalam', '96', '673'),
('33', 'BG', 'BGR', 'BULGARIA', '保加利亚', 'Bulgaria', '100', '359'),
('34', 'BF', 'BFA', 'BURKINA FASO', '布吉纳法索', 'Burkina Faso', '854', '226'),
('35', 'BI', 'BDI', 'BURUNDI', '布隆迪', 'Burundi', '108', '257'),
('36', 'KH', 'KHM', 'CAMBODIA', '柬埔寨', 'Cambodia', '116', '855'),
('37', 'CM', 'CMR', 'CAMEROON', '喀麦隆', 'Cameroon', '120', '237'),
('38', 'CA', 'CAN', 'CANADA', '加拿大', 'Canada', '124', '1'),
('39', 'CV', 'CPV', 'CAPE VERDE', '佛得角', 'Cape Verde', '132', '238'),
('40', 'KY', 'CYM', 'CAYMAN ISLANDS', '开曼群岛', 'Cayman Islands', '136', '1345'),
('41', 'CF', 'CAF', 'CENTRAL AFRICAN REPUBLIC', '中非共和国', 'Central African Republic', '140', '236'),
('42', 'TD', 'TCD', 'CHAD', '乍得', 'Chad', '148', '235'),
('43', 'CL', 'CHL', 'CHILE', '智利', 'Chile', '152', '56'),
('44', 'CN', 'CHN', 'CHINA', '中国', 'China', '156', '86'),
('45', 'CX', null, 'CHRISTMAS ISLAND', '圣诞岛', 'Christmas Island', null, '61'),
('46', 'CC', null, 'COCOS (KEELING) ISLANDS', 'COCOS(KEELING)岛', 'Cocos (Keeli