WIP: BugFix407 + Refactor #41
|
@ -1,68 +1,40 @@
|
|||
let isRead = true;
|
||||
let isChoose = true;
|
||||
let reader = window.speechSynthesis; // 全局定义朗读者,以便朗读和暂停
|
||||
let current_position = 0; // 朗读文本的当前位置
|
||||
let original_position = 0; // 朗读文本的初始位置
|
||||
let to_speak = ""; // 朗读的初始内容
|
||||
|
||||
var isRead = true;
|
||||
var isChoose = true;
|
||||
const reader = window.speechSynthesis; // 全局定义朗读者,以便朗读和暂停
|
||||
|
||||
//获取字符
|
||||
lijia
commented
Outdated
Review
注释规范:所有的注释部分"//"后面有且仅有一个空格。 注释规范:所有的注释部分"//"后面有且仅有一个空格。
|
||||
function getWord() {
|
||||
return window.getSelection ? window.getSelection() : document.selection.createRange().text;
|
||||
return window.getSelection
|
||||
lijia
commented
Outdated
Review
这里将两行代码化简为一行,看起来不那么繁琐,少定义一个变量也减少出错的概率,但是格式上要注意空格 ?和:的前后都要有空格 这里将两行代码化简为一行,看起来不那么繁琐,少定义一个变量也减少出错的概率,但是格式上要注意空格 ?和:的前后都要有空格
|
||||
? window.getSelection()
|
||||
: document.selection.createRange().text;
|
||||
}
|
||||
|
||||
function fillInWord() {
|
||||
let word = getWord();
|
||||
if (isRead) read(word);
|
||||
if (!isChoose) return;
|
||||
const element = document.getElementById("selected-words");
|
||||
element.value = element.value + " " + word;
|
||||
//填充字符
|
||||
lijia
commented
Outdated
Review
这里将var改成let我觉得用得很好,使得变量 这里将var改成let我觉得用得很好,使得变量 `word` 只在块级作用域起作用
|
||||
function fillingWord() {
|
||||
let word = getWord();
|
||||
if (isRead) read(word);
|
||||
XuLingLing
commented
Outdated
Review
将var替换为let,是最新的JavaScript语法 将var替换为let,是最新的JavaScript语法
XuLingLing
commented
Outdated
Review
这里有评审错误,将var改为let的原因是:let是块作用域,所以在块作用域内定义的变量,比如说在for循环内,在其外面是不可被访问的,所以for循环推荐用let。将var改为let这点做的很好。 这里有评审错误,将var改为let的原因是:let是块作用域,所以在块作用域内定义的变量,比如说在for循环内,在其外面是不可被访问的,所以for循环推荐用let。将var改为let这点做的很好。
|
||||
if (!isChoose) return;
|
||||
XuLingLing
commented
Outdated
Review
我觉得这里的代码可以改为 我觉得这里的代码可以改为`element.value += " " + word;`可以减少重复代码,让整个程序看起来更加简洁,结构清晰。
|
||||
let element = document.getElementById("selected-words");
|
||||
element.value = element.value + " " + word;
|
||||
}
|
||||
|
||||
document.getElementById("text-content").addEventListener("click", fillInWord, false);
|
||||
|
||||
function makeUtterance(str, rate) {
|
||||
let msg = new SpeechSynthesisUtterance(str);
|
||||
msg.rate = rate;
|
||||
msg.lang = "en-US"; // TODO: add language options menu
|
||||
msg.onboundary = ev => {
|
||||
if (ev.name == "word") {
|
||||
current_position = ev.charIndex;
|
||||
}
|
||||
}
|
||||
return msg;
|
||||
document
|
||||
.getElementById("text-content")
|
||||
XuLingLing
commented
Outdated
Review
这里将s改为了word,代码增强可读性,能够快速明白word代表的含义是要朗读的单词。改的好 这里将s改为了word,代码增强可读性,能够快速明白word代表的含义是要朗读的单词。改的好
|
||||
.addEventListener("click", fillingWord, false);
|
||||
//朗读单词
|
||||
XuLingLing
commented
Outdated
Review
这里完善了read函数,在创建新的朗读时,将旧的或者正在进行的朗读任务取消。相比于修改之前的函数,修改后的函数让整个项目更加严谨。 这里完善了read函数,在创建新的朗读时,将旧的或者正在进行的朗读任务取消。相比于修改之前的函数,修改后的函数让整个项目更加严谨。
|
||||
//@word 要朗读的单词
|
||||
function read(word) {
|
||||
lijia
commented
Outdated
Review
这里的let我觉得用得很好,限制了msg只在块级作用域起作用 这里的let我觉得用得很好,限制了msg只在块级作用域起作用
|
||||
//关闭当前正在读的单词
|
||||
reader.cancel();
|
||||
//创建新的朗读任务
|
||||
let msg = new SpeechSynthesisUtterance(word);
|
||||
reader.speak(msg);
|
||||
lijia
commented
Outdated
Review
let 是块级作用域,在带有let的块中声明的变量仅可在该块中使用。这里我觉得去掉let更好,因为在fillingWord()中也用到了isRead。 let 是块级作用域,在带有let的块中声明的变量仅可在该块中使用。这里我觉得去掉let更好,因为在fillingWord()中也用到了isRead。
|
||||
}
|
||||
|
||||
const sliderValue = document.getElementById("rangeValue"); // 显示值
|
||||
const inputSlider = document.getElementById("rangeComponent"); // 滑块元素
|
||||
inputSlider.oninput = () => {
|
||||
let value = inputSlider.value; // 获取滑块的值
|
||||
sliderValue.textContent = value + '×';
|
||||
if (!reader.speaking) return;
|
||||
reader.cancel();
|
||||
let msg = makeUtterance(to_speak.substring(original_position + current_position), value);
|
||||
original_position = original_position + current_position;
|
||||
current_position = 0;
|
||||
reader.speak(msg);
|
||||
};
|
||||
|
||||
function read(s) {
|
||||
to_speak = s.toString();
|
||||
original_position = 0;
|
||||
current_position = 0;
|
||||
let msg = makeUtterance(to_speak, inputSlider.value);
|
||||
reader.speak(msg);
|
||||
}
|
||||
|
||||
//关闭正在读的单词
|
||||
function onReadClick() {
|
||||
isRead = !isRead;
|
||||
if (!isRead) {
|
||||
reader.cancel();
|
||||
}
|
||||
}
|
||||
|
||||
function onChooseClick() {
|
||||
isChoose = !isChoose;
|
||||
}
|
||||
|
||||
function stopRead() {
|
||||
let isRead = !isRead;
|
||||
if (!isRead) {
|
||||
reader.cancel();
|
||||
}
|
||||
}
|
||||
}
|
||||
//取消当前选择
|
||||
function onChooseClick() {
|
||||
isChoose = !isChoose;
|
||||
}
|
||||
|
|
|
@ -1,217 +1,347 @@
|
|||
<!DOCTYPE html>
|
||||
<html lang="en">
|
||||
<head>
|
||||
<meta charset="UTF-8">
|
||||
<meta name="viewport"
|
||||
content="width=device-width, initial-scale=1.0, minimum-scale=0.5, maximum-scale=3.0, user-scalable=yes"/>
|
||||
<meta name="format-detection" content="telephone=no"/>
|
||||
<head>
|
||||
<meta charset="UTF-8" />
|
||||
<meta
|
||||
name="viewport"
|
||||
content="width=device-width, initial-scale=1.0, minimum-scale=0.5, maximum-scale=3.0, user-scalable=yes"
|
||||
/>
|
||||
<meta name="format-detection" content="telephone=no" />
|
||||
|
||||
{{ yml['header'] | safe }}
|
||||
{% if yml['css']['item'] %}
|
||||
{% for css in yml['css']['item'] %}
|
||||
<link href="{{ css }}" rel="stylesheet">
|
||||
{% endfor %}
|
||||
{% endif %}
|
||||
{% if yml['js']['head'] %}
|
||||
{% for js in yml['js']['head'] %}
|
||||
<script src="{{ js }}"></script>
|
||||
{% endfor %}
|
||||
{% endif %}
|
||||
{{ yml['header'] | safe }} {% if yml['css']['item'] %} {% for css in
|
||||
yml['css']['item'] %}
|
||||
<link href="{{ css }}" rel="stylesheet" />
|
||||
{% endfor %} {% endif %} {% if yml['js']['head'] %} {% for js in
|
||||
yml['js']['head'] %}
|
||||
<script src="{{ js }}"></script>
|
||||
{% endfor %} {% endif %}
|
||||
|
||||
<title>EnglishPal Study Room for {{ username }}</title>
|
||||
|
||||
<style>
|
||||
.shaking {
|
||||
animation: shakes 1600ms ease-in-out;
|
||||
}
|
||||
.shaking {
|
||||
animation: shakes 1600ms ease-in-out;
|
||||
}
|
||||
|
||||
@keyframes shakes {
|
||||
10%, 90% { transform: translate3d(-1px, 0, 0); }
|
||||
20%, 50% { transform: translate3d(+2px, 0, 0); }
|
||||
30%, 70% { transform: translate3d(-4px, 0, 0); }
|
||||
40%, 60% { transform: translate3d(+4px, 0, 0); }
|
||||
50% { transform: translate3d(-4px, 0, 0); }
|
||||
@keyframes shakes {
|
||||
10%,
|
||||
90% {
|
||||
transform: translate3d(-1px, 0, 0);
|
||||
}
|
||||
20%,
|
||||
50% {
|
||||
transform: translate3d(+2px, 0, 0);
|
||||
}
|
||||
30%,
|
||||
70% {
|
||||
transform: translate3d(-4px, 0, 0);
|
||||
}
|
||||
40%,
|
||||
60% {
|
||||
transform: translate3d(+4px, 0, 0);
|
||||
}
|
||||
50% {
|
||||
transform: translate3d(-4px, 0, 0);
|
||||
}
|
||||
}
|
||||
</style>
|
||||
</head>
|
||||
<body>
|
||||
<div class="container-fluid">
|
||||
<p><b>English Pal for <font id="username" color="red">{{ username }}</font></b>
|
||||
</head>
|
||||
<body>
|
||||
<div class="container-fluid">
|
||||
<p>
|
||||
<b
|
||||
>English Pal for
|
||||
<font id="username" color="red">{{ username }}</font></b
|
||||
>
|
||||
|
||||
{% if username == admin_name %}
|
||||
<a class="btn btn-secondary" href="/admin" role="button" onclick="stopRead()">管理</a>
|
||||
{% if username == admin_name %}
|
||||
<a
|
||||
class="btn btn-secondary"
|
||||
href="/admin"
|
||||
role="button"
|
||||
onclick="stopRead()"
|
||||
>管理</a
|
||||
>
|
||||
{% endif %}
|
||||
<a id="quit" class="btn btn-secondary" href="/logout" role="button" onclick="stopRead()">退出</a>
|
||||
<a class="btn btn-secondary" href="/reset" role="button" onclick="stopRead()">重设密码</a>
|
||||
<a
|
||||
id="quit"
|
||||
class="btn btn-secondary"
|
||||
href="/logout"
|
||||
role="button"
|
||||
onclick="stopRead()"
|
||||
>退出</a
|
||||
>
|
||||
<a
|
||||
class="btn btn-secondary"
|
||||
href="/reset"
|
||||
role="button"
|
||||
onclick="stopRead()"
|
||||
>重设密码</a
|
||||
>
|
||||
</p>
|
||||
{# {% for message in flashed_messages %}#} {#
|
||||
根据user_service.userpage,取消了参数flashed_messages,因此注释了这段代码
|
||||
#} {#
|
||||
<div class="alert alert-warning" role="alert">
|
||||
Congratulations! {{ message }}
|
||||
</div>
|
||||
#} {# {% endfor %}#}
|
||||
|
||||
</p>
|
||||
{# {% for message in flashed_messages %}#} {# 根据user_service.userpage,取消了参数flashed_messages,因此注释了这段代码 #}
|
||||
{# <div class="alert alert-warning" role="alert">Congratulations! {{ message }}</div>#}
|
||||
{# {% endfor %}#}
|
||||
<button
|
||||
class="btn btn-success"
|
||||
id="load_next_article"
|
||||
onclick="load_next_article()"
|
||||
>
|
||||
下一篇 Next Article
|
||||
</button>
|
||||
<button
|
||||
class="btn btn-success"
|
||||
id="load_pre_article"
|
||||
onclick="load_pre_article()"
|
||||
>
|
||||
上一篇 Previous Article
|
||||
</button>
|
||||
|
||||
<button class="btn btn-success" id="load_next_article" onclick="load_next_article()"> 下一篇 Next Article </button>
|
||||
<button class="btn btn-success" id="load_pre_article" onclick="load_pre_article()" > 上一篇 Previous Article </button>
|
||||
|
||||
<p><b>阅读文章并回答问题</b></p>
|
||||
<div id="text-content">
|
||||
<p><b>阅读文章并回答问题</b></p>
|
||||
<div id="text-content">
|
||||
<div id="found">
|
||||
<div class="alert alert-success" role="alert">According to your word list, your level is <span class="badge bg-success" id="user-level">{{ today_article["user_level"] }}</span> and we have chosen an article with a difficulty level of <span class="badge bg-success" id="text_level">{{ today_article["text_level"] }}</span> for you.</div>
|
||||
<p class="text-muted" id="date">Article added on: {{ today_article["date"] }}</p><br/>
|
||||
<div class="p-3 mb-2 bg-light text-dark"><br/>
|
||||
<p class="display-5" id="article_title">{{ today_article["article_title"] }}</p><br/>
|
||||
<p class="lead"><font id="article" size=2>{{ today_article["article_body"] }}</font></p><br/>
|
||||
<p><small class="text-muted" id="source">{{ today_article['source'] }}</small></p><br/>
|
||||
<p><b id="question">{{ today_article['question'] }}</b></p><br/>
|
||||
<script type="text/javascript">
|
||||
function toggle_visibility(id) { {# https://css-tricks.com/snippets/javascript/showhide-element/#}
|
||||
const e = document.getElementById(id);
|
||||
if(e.style.display === 'block')
|
||||
e.style.display = 'none';
|
||||
else
|
||||
e.style.display = 'block';
|
||||
}
|
||||
</script>
|
||||
<button onclick="toggle_visibility('answer');">ANSWER</button>
|
||||
<div id="answer" style="display:none;">{{ today_article['answer'] }}</div><br/>
|
||||
<div class="alert alert-success" role="alert">
|
||||
According to your word list, your level is
|
||||
<span class="badge bg-success" id="user-level"
|
||||
>{{ today_article["user_level"] }}</span
|
||||
>
|
||||
and we have chosen an article with a difficulty level of
|
||||
<span class="badge bg-success" id="text_level"
|
||||
>{{ today_article["text_level"] }}</span
|
||||
>
|
||||
for you.
|
||||
</div>
|
||||
<p class="text-muted" id="date">
|
||||
Article added on: {{ today_article["date"] }}
|
||||
</p>
|
||||
<br />
|
||||
<div class="p-3 mb-2 bg-light text-dark">
|
||||
<br />
|
||||
<p class="display-5" id="article_title">
|
||||
{{ today_article["article_title"] }}
|
||||
</p>
|
||||
<br />
|
||||
<p class="lead">
|
||||
<font id="article" size="2"
|
||||
>{{ today_article["article_body"] }}</font
|
||||
>
|
||||
</p>
|
||||
<br />
|
||||
<p>
|
||||
<small class="text-muted" id="source"
|
||||
>{{ today_article['source'] }}</small
|
||||
>
|
||||
</p>
|
||||
<br />
|
||||
<p><b id="question">{{ today_article['question'] }}</b></p>
|
||||
<br />
|
||||
<script type="text/javascript">
|
||||
function toggle_visibility(id) { {# https://css-tricks.com/snippets/javascript/showhide-element/#}
|
||||
const e = document.getElementById(id);
|
||||
if(e.style.display === 'block')
|
||||
e.style.display = 'none';
|
||||
else
|
||||
e.style.display = 'block';
|
||||
}
|
||||
</script>
|
||||
<button onclick="toggle_visibility('answer');">ANSWER</button>
|
||||
<div id="answer" style="display: none">
|
||||
{{ today_article['answer'] }}
|
||||
</div>
|
||||
<br />
|
||||
</div>
|
||||
</div>
|
||||
<div class="alert alert-success" role="alert" id="not_found" style="display:none;">
|
||||
<p class="text-muted"><span class="badge bg-success">Notes:</span><br>No article is currently available for you. You can try again a few times or mark new words in the passage to improve your level.</p>
|
||||
<div
|
||||
class="alert alert-success"
|
||||
role="alert"
|
||||
id="not_found"
|
||||
style="display: none"
|
||||
>
|
||||
<p class="text-muted">
|
||||
<span class="badge bg-success">Notes:</span><br />No article is
|
||||
currently available for you. You can try again a few times or mark
|
||||
new words in the passage to improve your level.
|
||||
</p>
|
||||
</div>
|
||||
<div class="alert alert-success" role="alert" id="read_all" style="display:none;">
|
||||
<p class="text-muted"><span class="badge bg-success">Notes:</span><br>You've read all the articles.</p>
|
||||
<div
|
||||
class="alert alert-success"
|
||||
role="alert"
|
||||
id="read_all"
|
||||
style="display: none"
|
||||
>
|
||||
<p class="text-muted">
|
||||
<span class="badge bg-success">Notes:</span><br />You've read all
|
||||
the articles.
|
||||
</p>
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
|
||||
<input type="checkbox" onclick="toggleHighlighting()" checked/>生词高亮
|
||||
<input type="checkbox" onclick="onReadClick()" checked/>大声朗读
|
||||
<input type="checkbox" onclick="onChooseClick()" checked/>划词入库
|
||||
<div class="range">
|
||||
<input type="checkbox" onclick="toggleHighlighting()" checked />生词高亮
|
||||
<input type="checkbox" onclick="onReadClick()" checked />大声朗读
|
||||
<input type="checkbox" onclick="onChooseClick()" checked />划词入库
|
||||
<div class="range">
|
||||
<div class="field">
|
||||
<div class="sliderValue">
|
||||
<span id="rangeValue">1×</span>
|
||||
</div>
|
||||
<input type="range" id="rangeComponent" min="0.5" max="2" value="1" step="0.25"/>
|
||||
<div class="sliderValue">
|
||||
<span id="rangeValue">1×</span>
|
||||
</div>
|
||||
<input
|
||||
type="range"
|
||||
id="rangeComponent"
|
||||
min="0.5"
|
||||
max="2"
|
||||
value="1"
|
||||
step="0.25"
|
||||
/>
|
||||
</div>
|
||||
</div>
|
||||
<p><b>收集生词吧</b> (可以在正文中划词,也可以复制黏贴)</p>
|
||||
<form method="post" action="/{{ username }}/userpage">
|
||||
<textarea name="content" id="selected-words" rows="10" cols="120"></textarea><br/>
|
||||
<input type="submit" value="把生词加入我的生词库"/>
|
||||
<input type="reset" value="清除"/>
|
||||
</form>
|
||||
{% if session.get['thisWord'] %}
|
||||
<script type="text/javascript">
|
||||
//point to the anchor in the page whose id is aaa if it exists
|
||||
window.onload = function () {
|
||||
var element = document.getElementsByName("aaa");
|
||||
if (element != null)
|
||||
document.getElementsByName("aaa")[0].scrollIntoView(true);
|
||||
}
|
||||
</script>
|
||||
{% endif %}
|
||||
|
||||
{% if d_len > 0 %}
|
||||
<p>
|
||||
<b>我的生词簿</b>
|
||||
<label for="move_dynamiclly">
|
||||
<input type="checkbox" name="move_dynamiclly" id="move_dynamiclly" checked>
|
||||
允许动态调整顺序
|
||||
</label>
|
||||
</div>
|
||||
<p><b>收集生词吧</b> (可以在正文中划词,也可以复制黏贴)</p>
|
||||
<form method="post" action="/{{ username }}/userpage">
|
||||
<textarea
|
||||
name="content"
|
||||
id="selected-words"
|
||||
rows="10"
|
||||
cols="120"
|
||||
></textarea
|
||||
><br />
|
||||
<input type="submit" value="把生词加入我的生词库" />
|
||||
<input type="reset" value="清除" />
|
||||
</form>
|
||||
{% if session.get['thisWord'] %}
|
||||
<script type="text/javascript">
|
||||
//point to the anchor in the page whose id is aaa if it exists
|
||||
window.onload = function () {
|
||||
var element = document.getElementsByName("aaa");
|
||||
if (element != null)
|
||||
document.getElementsByName("aaa")[0].scrollIntoView(true);
|
||||
};
|
||||
</script>
|
||||
{% endif %} {% if d_len > 0 %}
|
||||
<p>
|
||||
<b>我的生词簿</b>
|
||||
<label for="move_dynamiclly">
|
||||
<input
|
||||
type="checkbox"
|
||||
name="move_dynamiclly"
|
||||
id="move_dynamiclly"
|
||||
checked
|
||||
/>
|
||||
允许动态调整顺序
|
||||
</label>
|
||||
</p>
|
||||
<a name="aaa"></a>
|
||||
<div class="word-container">
|
||||
{% for x in lst3 %} {% set word = x[0] %} {% set freq = x[1] %} {% if
|
||||
session.get('thisWord') == x[0] and session.get('time') == 1 %} {% endif
|
||||
%}
|
||||
<p id="p_{{ word }}" class="new-word">
|
||||
<a
|
||||
id="word_{{ word }}"
|
||||
class="btn btn-light"
|
||||
href="http://youdao.com/w/eng/{{ word }}/#keyfrom=dict2.index"
|
||||
role="button"
|
||||
>{{ word }}</a
|
||||
>
|
||||
( <a id="freq_{{ word }}" title="{{ word }}">{{ freq }}</a> )
|
||||
<a
|
||||
class="btn btn-success"
|
||||
onclick="familiar('{{ word }}')"
|
||||
role="button"
|
||||
>熟悉</a
|
||||
>
|
||||
<a
|
||||
class="btn btn-warning"
|
||||
onclick="unfamiliar('{{ word }}')"
|
||||
role="button"
|
||||
>不熟悉</a
|
||||
>
|
||||
<a
|
||||
class="btn btn-danger"
|
||||
onclick="delete_word('{{ word }}')"
|
||||
role="button"
|
||||
>删除</a
|
||||
>
|
||||
</p>
|
||||
<a name="aaa"></a>
|
||||
<div class="word-container">
|
||||
{% for x in lst3 %}
|
||||
{% set word = x[0] %}
|
||||
{% set freq = x[1] %}
|
||||
{% if session.get('thisWord') == x[0] and session.get('time') == 1 %}
|
||||
{% endif %}
|
||||
<p id='p_{{ word }}' class="new-word" >
|
||||
<a id="word_{{ word }}" class="btn btn-light" href='http://youdao.com/w/eng/{{ word }}/#keyfrom=dict2.index'
|
||||
role="button">{{ word }}</a>
|
||||
( <a id="freq_{{ word }}" title="{{ word }}">{{ freq }}</a> )
|
||||
<a class="btn btn-success" onclick="familiar('{{ word }}')" role="button">熟悉</a>
|
||||
<a class="btn btn-warning" onclick="unfamiliar('{{ word }}')" role="button">不熟悉</a>
|
||||
<a class="btn btn-danger" onclick="delete_word('{{ word }}')" role="button">删除</a>
|
||||
</p>
|
||||
{% endfor %}
|
||||
</div>
|
||||
<input id="selected-words2" type="hidden" value="{{ words }}">
|
||||
{% endif %}
|
||||
</div>
|
||||
{{ yml['footer'] | safe }}
|
||||
{% if yml['js']['bottom'] %}
|
||||
{% for js in yml['js']['bottom'] %}
|
||||
<script src="{{ js }}"></script>
|
||||
{% endfor %}
|
||||
{% endif %}
|
||||
<script type="text/javascript">
|
||||
function load_next_article(){
|
||||
{% endfor %}
|
||||
</div>
|
||||
<input id="selected-words2" type="hidden" value="{{ words }}" />
|
||||
{% endif %}
|
||||
</div>
|
||||
{{ yml['footer'] | safe }} {% if yml['js']['bottom'] %} {% for js in
|
||||
yml['js']['bottom'] %}
|
||||
<script src="{{ js }}"></script>
|
||||
{% endfor %} {% endif %}
|
||||
<script type="text/javascript">
|
||||
function load_next_article() {
|
||||
$.ajax({
|
||||
url: '/get_next_article/{{username}}',
|
||||
dataType: 'json',
|
||||
success: function(data) {
|
||||
// 更新页面内容
|
||||
if(data['today_article']){
|
||||
update(data['today_article']);
|
||||
check_pre(data['visited_articles']);
|
||||
check_next(data['result_of_generate_article']);
|
||||
}
|
||||
url: "/get_next_article/{{username}}",
|
||||
dataType: "json",
|
||||
success: function (data) {
|
||||
// 更新页面内容
|
||||
if (data["today_article"]) {
|
||||
update(data["today_article"]);
|
||||
check_pre(data["visited_articles"]);
|
||||
check_next(data["result_of_generate_article"]);
|
||||
}
|
||||
},
|
||||
});
|
||||
}
|
||||
function load_pre_article(){
|
||||
}
|
||||
function load_pre_article() {
|
||||
$.ajax({
|
||||
url: '/get_pre_article/{{username}}',
|
||||
dataType: 'json',
|
||||
success: function(data) {
|
||||
// 更新页面内容
|
||||
if(data['today_article']){
|
||||
update(data['today_article']);
|
||||
check_pre(data['visited_articles']);
|
||||
}
|
||||
url: "/get_pre_article/{{username}}",
|
||||
dataType: "json",
|
||||
success: function (data) {
|
||||
// 更新页面内容
|
||||
if (data["today_article"]) {
|
||||
update(data["today_article"]);
|
||||
check_pre(data["visited_articles"]);
|
||||
}
|
||||
},
|
||||
});
|
||||
}
|
||||
function update(today_article){
|
||||
$('#user-level').html(today_article['user_level']);
|
||||
$('#text_level').html(today_article["text_level"]);
|
||||
$('#date').html('Article added on: '+today_article["date"]);
|
||||
$('#article_title').html(today_article["article_title"]);
|
||||
$('#article').html(today_article["article_body"]);
|
||||
$('#source').html(today_article['source']);
|
||||
$('#question').html(today_article["question"]);
|
||||
$('#answer').html(today_article["answer"]);
|
||||
}
|
||||
<!-- 检查是否存在上一篇或下一篇,不存在则对应按钮隐藏-->
|
||||
function check_pre(visited_articles){
|
||||
if((visited_articles=='')||(visited_articles['index']<=0)){
|
||||
$('#load_pre_article').hide();
|
||||
}else{
|
||||
$('#load_pre_article').show();
|
||||
}
|
||||
function update(today_article) {
|
||||
$("#user-level").html(today_article["user_level"]);
|
||||
$("#text_level").html(today_article["text_level"]);
|
||||
$("#date").html("Article added on: " + today_article["date"]);
|
||||
$("#article_title").html(today_article["article_title"]);
|
||||
$("#article").html(today_article["article_body"]);
|
||||
$("#source").html(today_article["source"]);
|
||||
$("#question").html(today_article["question"]);
|
||||
$("#answer").html(today_article["answer"]);
|
||||
}
|
||||
<!-- 检查是否存在上一篇或下一篇,不存在则对应按钮隐藏-->
|
||||
function check_pre(visited_articles) {
|
||||
if (visited_articles == "" || visited_articles["index"] <= 0) {
|
||||
$("#load_pre_article").hide();
|
||||
} else {
|
||||
$("#load_pre_article").show();
|
||||
}
|
||||
}
|
||||
function check_next(result_of_generate_article){
|
||||
if(result_of_generate_article == "found"){
|
||||
$('#found').show();$('#not_found').hide();
|
||||
$('#read_all').hide();
|
||||
}else if(result_of_generate_article == "not found"){
|
||||
$('#found').hide();
|
||||
$('#not_found').show();
|
||||
$('#read_all').hide();
|
||||
}else{
|
||||
$('#found').hide();
|
||||
$('#not_found').hide();
|
||||
$('#read_all').show();
|
||||
}
|
||||
function check_next(result_of_generate_article) {
|
||||
if (result_of_generate_article == "found") {
|
||||
$("#found").show();
|
||||
$("#not_found").hide();
|
||||
$("#read_all").hide();
|
||||
} else if (result_of_generate_article == "not found") {
|
||||
$("#found").hide();
|
||||
$("#not_found").show();
|
||||
$("#read_all").hide();
|
||||
} else {
|
||||
$("#found").hide();
|
||||
$("#not_found").hide();
|
||||
$("#read_all").show();
|
||||
}
|
||||
}
|
||||
</script>
|
||||
</body>
|
||||
<style>
|
||||
}
|
||||
</script>
|
||||
</body>
|
||||
<style>
|
||||
mark {
|
||||
color: #{{ yml['highlight']['color'] }};
|
||||
background-color: rgba(0, 0, 0, 0);
|
||||
}
|
||||
</style>
|
||||
|
||||
</style>
|
||||
</html>
|
||||
|
|
Loading…
Reference in New Issue
在变量前添加var类型,常量前增加const,增强代码可读性