匹配域后缀的正则表达式

a regular expression to match domains suffixes

本文关键字:正则表达式 后缀      更新时间:2023-09-26

我需要一些帮助来构建一个正则表达式,请。

我有一个域名数组和一个顶级域名数组(相当长)。例子:

tlds = {
    '.com':{
        1 : '£4.00',
        2 : '£7.50',
        3 : '£11.00',
        4 : '£14.50',
        5 : '£18.00',
    },
    '.org':{
        1 : '£5.00',
        2 : '£10.00',
        3 : '£15.00',
        4 : '£20.00',
        5 : '£25.00',
    },
    '.net':{
        1 : '£6.00',
        2 : '£12.00',
        3 : '£18.00',
        4 : '£24.00',
        5 : '£30.00',
    },
    '.co.uk':{
        1 : '£7.00',
        2 : '£14.00',
        3 : '£21.00',
        4 : '£28.00',
        5 : '£35.00',
    },
    '.com.br':{
        1 : '£9.00',
        2 : '£16.00',
        3 : '£22.00',
        4 : '£28.00',
        5 : '£34.00',
    }
}
domainResults = {
    0 : {
        'domain' : 'anything.com',
        'status' : 'available'
    },
    1 : {
        'domain' : 'anything-weird.org',
        'status' : 'available'
    },
    2 : {
        'domain' : 'anything-amazing.co.uk',
        'status' : 'available'
    }
}

对于每个域名,我想分配正确的tld。数组中的每个域名总是匹配其中一个tld。

我认为解决方案应该循环每个顶级域名作为一个REGEX,直到它匹配的域名我循环通过。

我知道这将是棘手的,因为我总是至少有26个顶级域名,我想确保它们都不匹配,以防止错误显示定价(例如:以'.com.br'结尾的域名不应该是'.com.br'的正则表达式的结果,但只适用于'.com.br')。

假设域名字符串中没有子域名部分

for(var index in domainResults){
    var domain = domainResults[index].domain;
    var tld = domain.substring(domain.indexOf("."));
    // now tlds[tld] gives the corresponding tld object
    console.log(tlds[tld]);
}