File size: 1,943 Bytes
de64bd3
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
document.addEventListener('DOMContentLoaded', function() {
    fetch('https://99i-tts.hf.space/voices?l=zh&d')
        .then(response => response.json())
        .then(data => {
            const voices = data.voices;
            displayVoices(voices);
            setupFilters(voices);
        });

    function displayVoices(voices) {
        const tableBody = document.getElementById('voicesTable').getElementsByTagName('tbody')[0];
        tableBody.innerHTML = ''; // 清空表格

        voices.forEach(voice => {
            const row = tableBody.insertRow();
            row.insertCell(0).innerText = voice.DisplayName;
            row.insertCell(1).innerText = voice.Gender;
            row.insertCell(2).innerText = voice.LocalName;
            row.insertCell(3).innerText = voice.LocaleName;
            row.insertCell(4).innerText = voice.Status;
            // 插入其他单元格
        });
    }

    function setupFilters(voices) {
        const genderSelect = document.getElementById('gender');
        const localeSelect = document.getElementById('locale');

        genderSelect.addEventListener('change', () => filterVoices());
        localeSelect.addEventListener('change', () => filterVoices());

        function filterVoices() {
            const selectedGender = genderSelect.value;
            const selectedLocale = localeSelect.value;

            const filteredVoices = voices.filter(voice => {
                return (selectedGender === '' || voice.Gender === selectedGender) &&
                       (selectedLocale === '' || voice.Locale === selectedLocale);
            });

            displayVoices(filteredVoices);
        }
    }
});
body {
    font-family: Arial, sans-serif;
}

#filters {
    margin-bottom: 20px;
}

table {
    width: 100%;
    border-collapse: collapse;
}

th, td {
    border: 1px solid #ddd;
    padding: 8px;
    text-align: left;
}

th {
    background-color: #f2f2f2;
}