gpt4 book ai didi

javascript - 使用 CSS 内容属性与 JavaScript

转载 作者:太空宇宙 更新时间:2023-11-04 10:06:39 25 4
gpt4 key购买 nike

我正在创建根据内容显示不同注释的输入。首先,我尝试使用 CSS 的 content 属性,但它只适用于 :before 和 :after 选择器。

因此,我创建了另一个 div 元素,在其上使用 :before 来显示注释文本。我应该改用 JavaScript 来执行此操作吗?

JS Fiddle

HTML:

<div class="link-input-container">
<input class="link-input" placeholder="Zalijepi link ovdje..." type="text" class="url_input" name="url_input">
</div>
<div class="link-note no-input">
<div class="link-note-content">
</div>
</div>

CSS:

.link-input-container {
position: relative;
display: inline-block;
}

.link-input-container::after {
display: block;
content: "";
width: 14px;
height: 14px;
background: transparent url('') no-repeat;
background-size: contain;
background-position: center;
position: absolute;
top: 50%;
right: -5px;
transform: translateY(-50%) translateX(100%);
}

.link-input-container.valid::after {
background-image: url('')
}

.link-input {
font-family: Courier New;
font-size: 12px;
}

.link-input-container.valid .link-input {
color: green;
}

.link-input-container:not(valid) .link-input {
color: red;
}

.link-note {
font-size: 12px;
}

.link-note.no-input {
color: rgb(193, 162, 0);
}

.link-note.no-input .link-note-content:before {
content: "*Link nije unesen";
}

.link-note.valid {
color: green;
}

.link-note.valid .link-note-content:before {
content: "*Stisni enter da dodas ovaj link";
}

.link-note.invalid {
color: red;
}

.link-note.invalid .link-note-content:before {
content: "*Link nije ispravan";
}

JS:

function toggleClass(elem, class_name, class_on) {
if (class_on) {
elem.classList.add(class_name);
} else {
elem.classList.remove(class_name);
}
}

function switchClass(elem, class_list, on_class) {
for (var i = 0; i < class_list.length; i++) {
elem.classList.remove(class_list[i]);
}
elem.classList.add(on_class);
}

function LinkInput() {
LinkInput = null;

var self = {
container_elem: null,
input_elem: null,
note_elem: null,

init: () => {
var container_elem = self.container_elem = document.querySelector(
'.link-input-container'
);

var input_elem = self.input_elem = document.querySelector(
'.link-input'
);
input_elem.size = 23;

var note_elem = self.note_elem = document.querySelector(
'.link-note'
);

input_elem.addEventListener('input', (ev) => {
var new_val = input_elem.value;

var new_size = new_val.length;
input_elem.size = Math.max(new_size + 2, 23);

if (new_val.length > 5) {
switchClass(note_elem, [
"no-input", "invalid", "valid"
], "valid");

toggleClass(container_elem, "valid", true);
} else {
if (new_val === "") {
switchClass(note_elem, [
"no-input", "invalid", "valid"
], "no-input");
} else {
switchClass(note_elem, [
"no-input", "invalid", "valid"
], "invalid");
}

toggleClass(container_elem, "valid", false);
}
});

input_elem.addEventListener('keyup', (ev) => {
if (ev.keyCode == 13) {
input_elem.value = "";
input_elem.blur();

// Submit

return false;
}
});
},
};

self.init();
return self;
}

var link_input = LinkInput();

最佳答案

这取决于你。我认为通知应该由 javascript 驱动,因为它在加载时不是网站的一部分。我在这里考虑一些 SEO,而不是搜索引擎无论如何都应该保存这样的通知。嗯,这就是我的意见 :)

干杯!

关于javascript - 使用 CSS 内容属性与 JavaScript,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/37944837/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com