如何在我选择的位置的对话框中显示一个小的JavaScript表单?

时间:2011-05-20 13:29:35

标签: javascript jquery html5

我有一个HTML5 Canvas。当用户双击该画布的特定区域时,我希望在该位置显示单字段表单,以便用户可以编辑某些文本。

我的预期效果类似于Google文档中的此屏幕截图。我用“Hello”文本双击了形状,出现了可编辑的文本字段。

我已经研究了如何检测双击,鼠标位置和文本。但到目前为止,我正在使用javascript“提示符(...)”对话框来编辑文本,这不是我想要的。

enter image description here

我想我正在寻找一些东西放在这个函数中来取代提示:

// let the user edit the text, by showing a popup-field that appears at (x, y)
function editText(x, y, text) {
    return prompt('Text:', text);
}

如果它是相关的,我正在使用jQuery。

1 个答案:

答案 0 :(得分:2)

爱普瑞斯似乎没有做你要求的所有事情所以我写了这个:http://jsfiddle.net/Qj9QR/12/

<强> CSS

.prompt { position: absolute; background-color: #E0ECFF; border-radius: 3px; width: 200px; height: 50px; border: 1px solid #99C0FF }
.prompt textarea { margin: 4px 0 0 4px  }
.prompt .hint { position: absolute; bottom: 1px; left: 5px; font-size: 9px; color: #444466 }

JS使用jQuery see fiddle

function prompt(opts){
    this.opts = $.extend({}, this.defaults, opts);
    this.init();
    this.open();
}

prompt.prototype = {
    defaults: { x: 0, y: 0, text: 'Type Here' },
    init: function(){
        this.create();
        this.bind();
        this.position();
    },
    bind: function(){
        var self = this;
        this.el.click(false).find('textarea').bind('keypress', function(e){
            if(e.which === 13) self.close(e);
        });
        $(document).bind('click.prompt', $.proxy(self.close, self));
    },
    close: function(e){
        if(this.opts.close){
            this.opts.close.apply(this, arguments);
        }
        if(!e.isPropagationStopped()){
            $(document).unbind('click', this.close);
            this.el.remove();
        }
    },
    create: function(){
        this.el = $('<div class="prompt" />')
            .append('<textarea></textarea>')
                .find('textarea').val(this.opts.text)
                .end()
            .append('<span class="hint">Hint: use Shift-Enter for multiple lines</span>');
    },
    position: function(){
        this.el.css({top: this.opts.y, left: this.opts.x });
    },
    open: function(){
        this.el.appendTo('body');
        this.el.show('fast')
            .find('textarea').focus().select();  
    } 
};
// IN USE: when you click an LI update some html
$('li').click(function(){
    var li = $(this),
        pos = li.position();
    new prompt({
        text: li.html(), 
        x: pos.left, 
        y: pos.top + 17, 
        close: function(e){
            var newText = $(e.target).val();
            newText && li.html(newText);
        } 
    });
    return false;
});

Updated with position and updating element values