【问题标题】:Adding url to string in array将url添加到数组中的字符串
【发布时间】:2017-08-03 23:24:34
【问题描述】:

我有一个脚本,可以一个一个地打印字母,一切正常。但是,我有一个大问题:有什么方法可以从将用作链接的数组中打印一个字符串?我正在尝试以多种方式添加 href,但没有成功。谁能给我一个关于如何做到这一点的线索?

这是脚本:

var text = document.getElementById('text');
var greeting = [
    'text that should be a link'
];
text.innerHTML = '<i>▮</i>';

(function greet() {
    if (greeting.length > 0 && greeting.length < 3) {
        text.insertBefore(document.createElement(' '), text.lastChild);
    }

    var line = greeting.shift();
    if (!line) {
        return;
    }

    line = line.split('');
    (function type() {
        var character = line.shift();
        if (!character) {
            return setTimeout(greet, 100);
        }

        text.insertBefore(document.createElement(character), text.lastChild);
        setTimeout(type, 20);
    }());
}());

【问题讨论】:

  • 你可以用完全相同的方式来做,但是href从哪里来,&lt;a&gt;元素在任何时候都可以点击,或者只有在完整的字符串出现在元素?
  • 如果我可以在数组 'click' 中设置类似的内容,我会很高兴,但是当我这样做时,它会将其打印为普通文本
  • 出于好奇,当你运行它时,发布的脚本是否有效,对我来说,它(正确地)在粘贴到 JS Fiddle 时会产生错误;你能发布你描述的工作代码吗?
  • jsfiddle.net/78mw1mfL/11 这与我的 index.html 上的代码完全相同,不知道为什么在 fiddle 上不起作用
  • 查看浏览器的开发者工具(在大多数浏览器中为“F12”); JavaScript 控制台将显示错误,说明什么不起作用。

标签: javascript arrays string url


【解决方案1】:

这样的东西会创建 html 锚链接:

var text = document.getElementById('text');
var greeting = [
    { url:'www.google.com', text: 'google' }  // an example of data.
];


(function greet() {
    if (greeting.length > 0 && greeting.length < 3) {
       var link = createLink(greeting[0].url,greeting[0].text);
       text.append(link);
    }

    function createLink(url, text) {
        var a = document.createElement('a');
        a.innerHTML = '<i>▮</i>';
        a.title = text;
        a.href = url;
        return a;
    }

    // rest of your code.

}());

这是一个例子JsFiddle

【讨论】:

  • 不太确定如何将它与我的代码结合起来,因为当我这样做时,我得到了错误,这就是我的脚本的样子:jsfiddle.net/78mw1mfL/11 不确定为什么在小提琴上它不起作用但在本地主机和服务器上工作得很好
  • 你想如何使用链接? &lt;a&gt;kbuild-dir := $(if $(filter /%,&lt;/a&gt; ?
  • 只需将document.createElement(' ') 更改为document.createElement('a') 即可“工作”,但您是否想要&lt;a&gt;&lt;/a&gt; 中的数组内容?
猜你喜欢
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 2023-01-19
  • 1970-01-01
  • 1970-01-01
  • 2017-06-26
  • 2011-10-19
  • 1970-01-01
相关资源
最近更新 更多