Metin giriş alanları

Metin girişi alanı, değer olarak bir dize, metin olarak da bir dize depolar. Değeri her zaman geçerli bir dizedir. Metni ise düzenleyicisine girilen herhangi bir dize olabilir.

Metin giriş alanı

"Metin girişi:" etiketli bir blok ve "varsayılan
metin" olarak ayarlanmış bir metin girişi alanı.

Düzenleyici açıkken metin giriş alanı

Düzenlenen alanla aynı blok.

Daraltılmış bloktaki metin giriş alanı

Aynı blok daraltıldıktan sonra. "Metin girişi: varsayılan metin" etiketine sahiptir ve daraltıldığını göstermek için sağ kenarı tırtıklıdır.

içerik üretimi

JSON

{
  "type": "example_textinput",
  "message0": "text input: %1",
  "args0": [
    {
      "type": "field_input",
      "name": "FIELDNAME",
      "text": "default text",
      "spellcheck": false
    }
  ]
}

JavaScript

Blockly.Blocks['example_textinput'] = {
  init: function() {
    this.appendDummyInput()
        .appendField("text input:")
        .appendField(new Blockly.FieldTextInput('default text'),
            'FIELDNAME');
  }
};

Metin girişi oluşturucusu, isteğe bağlı bir değer ve isteğe bağlı bir doğrulayıcı alır. Değer, dizeye dönüştürülmelidir. null veya undefined ise boş bir dize kullanılır.

JSON tanımı, yazım denetimi seçeneğini ayarlamanıza da olanak tanır.

Serileştirme ve XML

JSON

Metin girişi alanı için JSON şu şekilde görünür:

{
  "fields": {
    "FIELDNAME": "text"
  }
}

Burada FIELDNAME, bir metin girişi alanına referans veren bir dizedir ve değer, alana uygulanacak değerdir. Değer, oluşturucu değeriyle aynı kurallara uyar.

XML

Metin giriş alanı için XML şu şekilde görünür:

<field name="FIELDNAME">text</field>

Alanının name özelliği, bir metin girişi alanına referans veren bir dize içerir ve iç metin, alana uygulanacak değerdir. İç metin değeri, oluşturucu değeriyle aynı kurallara uyar.

Özelleştirme

Yazım denetimi

setSpellcheck işlevi, alanın giriş metninde yazım denetimi yapıp yapmayacağını ayarlamak için kullanılabilir.

Yazım denetimli ve yazım denetimsiz metin giriş alanları

Metin giriş alanları içeren iki blok gösteren hareketli GIF. İlk blokta yazım denetimi açıktır ve yanlış yazılmış kelimelerin altı dalgalı kırmızı çizgiyle çizilir. İkinci blokta yazım denetimi devre dışı ve yanlış yazılan kelimelerin altı çizilmiyor.

Yazım denetimi varsayılan olarak etkindir.

Bu durum, bağımsız alanlar için geçerlidir. Tüm alanları değiştirmek istiyorsanız Blockly.FieldTextInput.prototype.spellcheck_ özelliğini değiştirin.

Metin girişi doğrulayıcısı oluşturma

Metin girişi alanının değeri bir dizedir. Bu nedenle, tüm doğrulayıcılar bir dizeyi kabul etmeli ve bir dize, null veya undefined döndürmelidir.

Aşağıda, dizedeki tüm a karakterlerini kaldıran bir doğrulayıcı örneği verilmiştir:

function(newValue) {
  return newValue.replace(/a/g, '');
}

Bir metin giriş alanının doğrulandığını gösteren hareketli GIF. Kullanıcı &quot;bbbaaa&quot; yazıp başka bir yeri tıkladığında alan &quot;bbb&quot; olarak değiştirilir.