-
Notifications
You must be signed in to change notification settings - Fork 244
/
Copy pathindex.html
184 lines (160 loc) · 6.36 KB
/
index.html
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
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title>能不能好好说话?</title>
<link rel="stylesheet" href="base.css">
<link rel="stylesheet" href="nbnhhsh.css">
<link rel="stylesheet" href="document.css">
<meta name="viewport" content="width=device-width,user-scalable=0">
</head>
<body>
<header>
<h1>能不能好好说话?</h1>
<p>拼音首字母缩写释义工具</p>
</header>
<div id="el">
<textarea v-model="text" placeholder="输入含有首字母缩写的文字" @input="nbnhhsh()"></textarea>
<div class="func-nbnhhsh-box" v-if="show">
<div class="nbnhhsh-loading" v-if="loading">
加载中…
</div>
<div class="nbnhhsh-tag-list" v-else-if="tags.length">
<div class="nbnhhsh-tag-item" v-for="tag in tags">
<h4>{{tag.name}}</h4>
<div class="nbnhhsh-tran-list" v-if="tag.trans">
<span class="nbnhhsh-tran-item" v-for="tran in tag.trans">{{tran}}</span>
</div>
<div class="nbnhhsh-notran-box" v-else-if="tag.trans===null">
无对应文字
</div>
<div v-else-if="tag.inputting && tag.inputting.length !==0">
<div class="nbnhhsh-inputting-list">
<h5>有可能是</h5>
<span class="nbnhhsh-inputting-item" v-for="input in tag.inputting">{{input}}</span>
</div>
</div>
<div class="nbnhhsh-notran-box" v-else @click.prevent="submitTran(tag.name)">
尚未录入,我来提交对应文字
</div>
<a v-if="tag.trans!==null" @click.prevent="submitTran(tag.name)" class="nbnhhsh-add-btn" title="我来提交对应文字"></a>
</div>
</div>
<div class="nbnhhsh-loading" v-else>
没有匹配到拼音首字母缩写
</div>
</div>
</div>
<div class="content-box">
<h2>例文</h2>
<blockquote>
<p>草这个tmd网络世界我真的太恨缩写了。</p>
<p>
随便点开一条微博,艺人名字要缩写,gzs工作室也要缩写,gc广场他妈的也是缩写,hgr老子猜了老半天,百度一下才知道是韩国人,拳头硬了。<br>
讲个话开头也缩写,srds虽然但是,yjgj有句港句,bbl求求了。(这个谁看得出来你妈的)<br>
夸人骂人也都缩写,yjjc一骑绝尘,wdcc弯道超车,yygq阴阳怪气,myss美颜盛世,rnb我也猜了半天,最后被告知是really牛b的意思,哈哈哈哈哈哈哈哈哈哈哈哈哈哈哈哈哈又硬了呢。<br>
最要命的还不是这些,我刚刚看到网友评价什么什么他jb的什么,我以为jb就是jb的意思吧,但联系上下文句子又读不通,想了一分钟,哇,原来jb是姜滨的缩写啊!<br>
jb=姜滨,我离开了。</p>
<p>@你里哥哥</p>
</blockquote>
<h2>为什么做这东西?</h2>
<p>社交平台上通过拼音首字母缩写指代特定词句的情况越来越多,为了让更多人能勉强理解这一门另类沟通方式、做了这一个划词转义工具。</p>
<h2>什么是用户脚本?</h2>
<p>用户脚本是一段代码,它们能够优化您的网页浏览体验。安装之后,有些脚本能为网站添加新的功能,有些能使网站的界面更加易用,有些则能隐藏网站上烦人的部分内容。用户脚本都是由用户编写并向全世界发表的,您可以免费安装,轻松体验。</p>
<p>安装过程可参考 <a href="https://greasyfork.org/zh-CN/#home-step-1" target="_blank">https://greasyfork.org/zh-CN/</a> 首页的,<b>第一步:安装一个用户脚本管理器</b> 章节</p>
<h2>如何安装网页划词释义用户脚本?</h2>
<p>安装好用户脚本浏览器插件之后,访问 <a href="nbnhhsh.user.js">nbnhhsh.user.js</a> 完成脚本安装</p>
<blockquote>
<p>脚本版本目前仅会在 <code>https://weibo.com/</code> 页面下运行,划词时会提交所选文字以用于转义。</p>
</blockquote>
<h2>如何在更多网站上使用这个用户脚本?</h2>
<p>在对应的用户脚本配置里可以设置 <b>用户匹配</b>,添加对应 URL 规则即可。</p>
<h2>贡献词条</h2>
<p>在每一个词条右上角都有 <code>+</code> 图标的按钮,点击可以提交对应文字,审核后会整理录入。</p>
<h2>有更离谱的例文?</h2>
<p>请用任意方式发我!😖</p>
<h2>仓库地址</h2>
<p><a href="https://github.com/itorr/nbnhhsh" target="_blank">https://github.com/itorr/nbnhhsh</a></p>
</div>
<script src="https://cdn.bootcss.com/vue/2.6.11/vue.min.js"></script>
<script>
(()=>{
const APIURL = 'https://lab.magiconch.com/api/nbnhhsh/';
const Nbnhhsh = {};
const request = (method,url,data,onOver)=>{
let x = new XMLHttpRequest();
x.open(method,url);
x.setRequestHeader('content-type', 'application/json');
x.withCredentials = true;
x.onload = ()=> onOver(guess.x.responseText?JSON.parse(guess.x.responseText):guess.x.responseText);
x.send(JSON.stringify(data));
return x;
};
const guess = (text,onOver)=>{
text = text.trim();
if(Nbnhhsh[text]){
return onOver(Nbnhhsh[text]);
}
if(guess.x){
guess.x.abort();
}
app.loading = true;
guess.x = request('POST',APIURL+'guess',{text},data=>{
Nbnhhsh[text] = data;
onOver(data);
app.loading = false;
});
};
const _guess = (text,onOver)=>{
clearTimeout(_guess.t);
_guess.t=setTimeout(guess.bind(this,text,onOver),300);
};
const submitTran = name=>{
let text = prompt('输入缩写对应文字','');
if(!text || !text.trim || !text.trim()){
return;
}
request('POST',APIURL+'translation/'+name,{text},()=>{
alert('感谢对好好说话项目的支持!审核通过后这条对应将会生效');
});
};
const app = new Vue({
el,
data: {
text:'',
tags:[],
loading:false,
show:false
},
methods: {
submitTran,
nbnhhsh(){
let text = this.text;
app.show = !!text && /[a-z0-9]/i.test(text);
if(!app.show){
return;
}
_guess(text,data=>{
if(data.error){
app.error = data.error;
}else{
app.error = null;
app.tags = data;
}
});
}
}
});
const loadJS = (src,el) =>{
el = document.createElement('script');
el.src = src;
document.body.appendChild(el);
};
setTimeout(()=>{
loadJS('//s4.cnzz.com/z_stat.php?id=1278706389&web_id=1278706389');
},400);
})();
</script>
<script src="nbnhhsh.user.js"></script>
</body>
</html>