Creating nested elements dynamicallyCreate GUID / UUID in JavaScript?How do I detect a click outside an element?How do I check if an element is hidden in jQuery?Event binding on dynamically created elements?Retrieve the position (X,Y) of an HTML elementHow do I find out which DOM element has the focus?Creating a div element in jQueryHow to move an element into another element?How do I remove a particular element from an array in JavaScript?jQuery scroll to element

Does "Dominei" mean something?

Is exact Kanji stroke length important?

Java - What do constructor type arguments mean when placed *before* the type?

Would it be legal for a US State to ban exports of a natural resource?

Lifted its hind leg on or lifted its hind leg towards?

Superhero words!

Are Warlocks Arcane or Divine?

How can a jailer prevent the Forge Cleric's Artisan's Blessing from being used?

Indicating multiple different modes of speech (fantasy language or telepathy)

Should my PhD thesis be submitted under my legal name?

Freedom of speech and where it applies

A workplace installs custom certificates on personal devices, can this be used to decrypt HTTPS traffic?

In Star Trek IV, why did the Bounty go back to a time when whales were already rare?

How can I successfully establish a nationwide combat training program for a large country?

Can I create an upright 7-foot × 5-foot wall with the Minor Illusion spell?

Why does this part of the Space Shuttle launch pad seem to be floating in air?

How can I raise concerns with a new DM about XP splitting?

Bob has never been a M before

Can a Gentile theist be saved?

Is there a problem with hiding "forgot password" until it's needed?

Simple recursive Sudoku solver

Meta programming: Declare a new struct on the fly

What if somebody invests in my application?

Adding empty element to declared container without declaring type of element



Creating nested elements dynamically


Create GUID / UUID in JavaScript?How do I detect a click outside an element?How do I check if an element is hidden in jQuery?Event binding on dynamically created elements?Retrieve the position (X,Y) of an HTML elementHow do I find out which DOM element has the focus?Creating a div element in jQueryHow to move an element into another element?How do I remove a particular element from an array in JavaScript?jQuery scroll to element













9















I have this array of strings var arr = ["ul", "li", "strong", "em", "u"].



How can I make these into DOM Elements one inside another from left to right, first element as the root element. Without using ID because of some reason.



And maybe by using loop for it to be flexible to any number of elements.



var new_element = document.createElement(arr[0]);



I'm expecting something like this:



<ul>
<li><strong><em><u>Text Here</u></em></strong></li>
</ul>


Thank you.










share|improve this question



















  • 1





    You want to know about Node.appendChild.

    – moonwave99
    2 days ago















9















I have this array of strings var arr = ["ul", "li", "strong", "em", "u"].



How can I make these into DOM Elements one inside another from left to right, first element as the root element. Without using ID because of some reason.



And maybe by using loop for it to be flexible to any number of elements.



var new_element = document.createElement(arr[0]);



I'm expecting something like this:



<ul>
<li><strong><em><u>Text Here</u></em></strong></li>
</ul>


Thank you.










share|improve this question



















  • 1





    You want to know about Node.appendChild.

    – moonwave99
    2 days ago













9












9








9


1






I have this array of strings var arr = ["ul", "li", "strong", "em", "u"].



How can I make these into DOM Elements one inside another from left to right, first element as the root element. Without using ID because of some reason.



And maybe by using loop for it to be flexible to any number of elements.



var new_element = document.createElement(arr[0]);



I'm expecting something like this:



<ul>
<li><strong><em><u>Text Here</u></em></strong></li>
</ul>


Thank you.










share|improve this question
















I have this array of strings var arr = ["ul", "li", "strong", "em", "u"].



How can I make these into DOM Elements one inside another from left to right, first element as the root element. Without using ID because of some reason.



And maybe by using loop for it to be flexible to any number of elements.



var new_element = document.createElement(arr[0]);



I'm expecting something like this:



<ul>
<li><strong><em><u>Text Here</u></em></strong></li>
</ul>


Thank you.







javascript html dom






share|improve this question















share|improve this question













share|improve this question




share|improve this question








edited 2 days ago









Community

11




11










asked 2 days ago









MuyieMuyie

728




728







  • 1





    You want to know about Node.appendChild.

    – moonwave99
    2 days ago












  • 1





    You want to know about Node.appendChild.

    – moonwave99
    2 days ago







1




1





You want to know about Node.appendChild.

– moonwave99
2 days ago





You want to know about Node.appendChild.

– moonwave99
2 days ago












3 Answers
3






active

oldest

votes


















7














You can do this with reduceRight() which avoids needing to query the result to get the deepest value because it starts with the deepest element and works out. The return value will be the topmost element:






var arr = ["ul", "li", "strong", "em", "u"]

let el = arr.reduceRight((el, n) =>
let d = document.createElement(n)
d.appendChild(el)
return d
, document.createTextNode("Text Here"))

document.getElementById('container').appendChild(el)

<div id = "container"></div>





It also fails gracefully with an empty array:






var arr = []

let el = arr.reduceRight((el, n) =>
let d = document.createElement(n)
d.appendChild(el)
return d
, document.createTextNode("Text Here"))

document.getElementById('container').appendChild(el)

<div id = "container"></div>








share|improve this answer


















  • 1





    Great! Works as expected. I'll be analyzing how this works and read about the reduce and reduceRight function. Thank you

    – Muyie
    2 days ago


















11














You can use Array.prototype.reduce and Node.prototype.appendChild.



https://jsbin.com/hizetekato/edit?html,js,output






var arr = ["ul", "li", "strong", "em", "u"];

function createChildren(mount, arr)
return arr.reduce((parent, elementName, i) =>
const element = document.createElement(elementName);
parent.appendChild(element);
return element;
, mount);


const deepest = createChildren(document.querySelector('#root'), arr);

deepest.innerText = 'WebDevNSK'

<div id="root"></div>








share|improve this answer

























  • Seems like this is what I am looking for. I'll try to analyze it. And read about .reduce() Thank you btw.

    – Muyie
    2 days ago











  • What about => parent.appendChild(document.createElement(elementName));? Node.appendChild returns the appended child. However, readability is probably more important that concision.

    – Solomon Ucko
    2 days ago


















0














createDocumentFragment() and run the array through a loop. On each iteration createElement() and appendChild()






const frag = document.createDocumentFragment();
const useless = ["ul", "li", "strong", "em", "u"];

let previous;
for (let u = 0; u < useless.length; u++)
const current = document.createElement(useless[u]);
if (u === 0)
frag.appendChild(current);
else
previous.appendChild(current);

previous = current;


document.body.appendChild(frag);

ul 
outline: 5px dashed green;
padding: 15px;


li
outline: 5px solid blue;
padding: 12px;


strong
outline: 5px dashed red;
padding: 9px


em
outline: 5px dashed grey;
padding: 6px


u
outline: 5px solid black;
padding: 3px;


u::before
content: 'THIS TEXT SHOULD BE UNDERLINED'








share|improve this answer






















    Your Answer






    StackExchange.ifUsing("editor", function ()
    StackExchange.using("externalEditor", function ()
    StackExchange.using("snippets", function ()
    StackExchange.snippets.init();
    );
    );
    , "code-snippets");

    StackExchange.ready(function()
    var channelOptions =
    tags: "".split(" "),
    id: "1"
    ;
    initTagRenderer("".split(" "), "".split(" "), channelOptions);

    StackExchange.using("externalEditor", function()
    // Have to fire editor after snippets, if snippets enabled
    if (StackExchange.settings.snippets.snippetsEnabled)
    StackExchange.using("snippets", function()
    createEditor();
    );

    else
    createEditor();

    );

    function createEditor()
    StackExchange.prepareEditor(
    heartbeatType: 'answer',
    autoActivateHeartbeat: false,
    convertImagesToLinks: true,
    noModals: true,
    showLowRepImageUploadWarning: true,
    reputationToPostImages: 10,
    bindNavPrevention: true,
    postfix: "",
    imageUploader:
    brandingHtml: "Powered by u003ca class="icon-imgur-white" href="https://imgur.com/"u003eu003c/au003e",
    contentPolicyHtml: "User contributions licensed under u003ca href="https://creativecommons.org/licenses/by-sa/3.0/"u003ecc by-sa 3.0 with attribution requiredu003c/au003e u003ca href="https://stackoverflow.com/legal/content-policy"u003e(content policy)u003c/au003e",
    allowUrls: true
    ,
    onDemand: true,
    discardSelector: ".discard-answer"
    ,immediatelyShowMarkdownHelp:true
    );



    );













    draft saved

    draft discarded


















    StackExchange.ready(
    function ()
    StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fstackoverflow.com%2fquestions%2f55311908%2fcreating-nested-elements-dynamically%23new-answer', 'question_page');

    );

    Post as a guest















    Required, but never shown

























    3 Answers
    3






    active

    oldest

    votes








    3 Answers
    3






    active

    oldest

    votes









    active

    oldest

    votes






    active

    oldest

    votes









    7














    You can do this with reduceRight() which avoids needing to query the result to get the deepest value because it starts with the deepest element and works out. The return value will be the topmost element:






    var arr = ["ul", "li", "strong", "em", "u"]

    let el = arr.reduceRight((el, n) =>
    let d = document.createElement(n)
    d.appendChild(el)
    return d
    , document.createTextNode("Text Here"))

    document.getElementById('container').appendChild(el)

    <div id = "container"></div>





    It also fails gracefully with an empty array:






    var arr = []

    let el = arr.reduceRight((el, n) =>
    let d = document.createElement(n)
    d.appendChild(el)
    return d
    , document.createTextNode("Text Here"))

    document.getElementById('container').appendChild(el)

    <div id = "container"></div>








    share|improve this answer


















    • 1





      Great! Works as expected. I'll be analyzing how this works and read about the reduce and reduceRight function. Thank you

      – Muyie
      2 days ago















    7














    You can do this with reduceRight() which avoids needing to query the result to get the deepest value because it starts with the deepest element and works out. The return value will be the topmost element:






    var arr = ["ul", "li", "strong", "em", "u"]

    let el = arr.reduceRight((el, n) =>
    let d = document.createElement(n)
    d.appendChild(el)
    return d
    , document.createTextNode("Text Here"))

    document.getElementById('container').appendChild(el)

    <div id = "container"></div>





    It also fails gracefully with an empty array:






    var arr = []

    let el = arr.reduceRight((el, n) =>
    let d = document.createElement(n)
    d.appendChild(el)
    return d
    , document.createTextNode("Text Here"))

    document.getElementById('container').appendChild(el)

    <div id = "container"></div>








    share|improve this answer


















    • 1





      Great! Works as expected. I'll be analyzing how this works and read about the reduce and reduceRight function. Thank you

      – Muyie
      2 days ago













    7












    7








    7







    You can do this with reduceRight() which avoids needing to query the result to get the deepest value because it starts with the deepest element and works out. The return value will be the topmost element:






    var arr = ["ul", "li", "strong", "em", "u"]

    let el = arr.reduceRight((el, n) =>
    let d = document.createElement(n)
    d.appendChild(el)
    return d
    , document.createTextNode("Text Here"))

    document.getElementById('container').appendChild(el)

    <div id = "container"></div>





    It also fails gracefully with an empty array:






    var arr = []

    let el = arr.reduceRight((el, n) =>
    let d = document.createElement(n)
    d.appendChild(el)
    return d
    , document.createTextNode("Text Here"))

    document.getElementById('container').appendChild(el)

    <div id = "container"></div>








    share|improve this answer













    You can do this with reduceRight() which avoids needing to query the result to get the deepest value because it starts with the deepest element and works out. The return value will be the topmost element:






    var arr = ["ul", "li", "strong", "em", "u"]

    let el = arr.reduceRight((el, n) =>
    let d = document.createElement(n)
    d.appendChild(el)
    return d
    , document.createTextNode("Text Here"))

    document.getElementById('container').appendChild(el)

    <div id = "container"></div>





    It also fails gracefully with an empty array:






    var arr = []

    let el = arr.reduceRight((el, n) =>
    let d = document.createElement(n)
    d.appendChild(el)
    return d
    , document.createTextNode("Text Here"))

    document.getElementById('container').appendChild(el)

    <div id = "container"></div>








    var arr = ["ul", "li", "strong", "em", "u"]

    let el = arr.reduceRight((el, n) =>
    let d = document.createElement(n)
    d.appendChild(el)
    return d
    , document.createTextNode("Text Here"))

    document.getElementById('container').appendChild(el)

    <div id = "container"></div>





    var arr = ["ul", "li", "strong", "em", "u"]

    let el = arr.reduceRight((el, n) =>
    let d = document.createElement(n)
    d.appendChild(el)
    return d
    , document.createTextNode("Text Here"))

    document.getElementById('container').appendChild(el)

    <div id = "container"></div>





    var arr = []

    let el = arr.reduceRight((el, n) =>
    let d = document.createElement(n)
    d.appendChild(el)
    return d
    , document.createTextNode("Text Here"))

    document.getElementById('container').appendChild(el)

    <div id = "container"></div>





    var arr = []

    let el = arr.reduceRight((el, n) =>
    let d = document.createElement(n)
    d.appendChild(el)
    return d
    , document.createTextNode("Text Here"))

    document.getElementById('container').appendChild(el)

    <div id = "container"></div>






    share|improve this answer












    share|improve this answer



    share|improve this answer










    answered 2 days ago









    Mark MeyerMark Meyer

    39.7k33262




    39.7k33262







    • 1





      Great! Works as expected. I'll be analyzing how this works and read about the reduce and reduceRight function. Thank you

      – Muyie
      2 days ago












    • 1





      Great! Works as expected. I'll be analyzing how this works and read about the reduce and reduceRight function. Thank you

      – Muyie
      2 days ago







    1




    1





    Great! Works as expected. I'll be analyzing how this works and read about the reduce and reduceRight function. Thank you

    – Muyie
    2 days ago





    Great! Works as expected. I'll be analyzing how this works and read about the reduce and reduceRight function. Thank you

    – Muyie
    2 days ago













    11














    You can use Array.prototype.reduce and Node.prototype.appendChild.



    https://jsbin.com/hizetekato/edit?html,js,output






    var arr = ["ul", "li", "strong", "em", "u"];

    function createChildren(mount, arr)
    return arr.reduce((parent, elementName, i) =>
    const element = document.createElement(elementName);
    parent.appendChild(element);
    return element;
    , mount);


    const deepest = createChildren(document.querySelector('#root'), arr);

    deepest.innerText = 'WebDevNSK'

    <div id="root"></div>








    share|improve this answer

























    • Seems like this is what I am looking for. I'll try to analyze it. And read about .reduce() Thank you btw.

      – Muyie
      2 days ago











    • What about => parent.appendChild(document.createElement(elementName));? Node.appendChild returns the appended child. However, readability is probably more important that concision.

      – Solomon Ucko
      2 days ago















    11














    You can use Array.prototype.reduce and Node.prototype.appendChild.



    https://jsbin.com/hizetekato/edit?html,js,output






    var arr = ["ul", "li", "strong", "em", "u"];

    function createChildren(mount, arr)
    return arr.reduce((parent, elementName, i) =>
    const element = document.createElement(elementName);
    parent.appendChild(element);
    return element;
    , mount);


    const deepest = createChildren(document.querySelector('#root'), arr);

    deepest.innerText = 'WebDevNSK'

    <div id="root"></div>








    share|improve this answer

























    • Seems like this is what I am looking for. I'll try to analyze it. And read about .reduce() Thank you btw.

      – Muyie
      2 days ago











    • What about => parent.appendChild(document.createElement(elementName));? Node.appendChild returns the appended child. However, readability is probably more important that concision.

      – Solomon Ucko
      2 days ago













    11












    11








    11







    You can use Array.prototype.reduce and Node.prototype.appendChild.



    https://jsbin.com/hizetekato/edit?html,js,output






    var arr = ["ul", "li", "strong", "em", "u"];

    function createChildren(mount, arr)
    return arr.reduce((parent, elementName, i) =>
    const element = document.createElement(elementName);
    parent.appendChild(element);
    return element;
    , mount);


    const deepest = createChildren(document.querySelector('#root'), arr);

    deepest.innerText = 'WebDevNSK'

    <div id="root"></div>








    share|improve this answer















    You can use Array.prototype.reduce and Node.prototype.appendChild.



    https://jsbin.com/hizetekato/edit?html,js,output






    var arr = ["ul", "li", "strong", "em", "u"];

    function createChildren(mount, arr)
    return arr.reduce((parent, elementName, i) =>
    const element = document.createElement(elementName);
    parent.appendChild(element);
    return element;
    , mount);


    const deepest = createChildren(document.querySelector('#root'), arr);

    deepest.innerText = 'WebDevNSK'

    <div id="root"></div>








    var arr = ["ul", "li", "strong", "em", "u"];

    function createChildren(mount, arr)
    return arr.reduce((parent, elementName, i) =>
    const element = document.createElement(elementName);
    parent.appendChild(element);
    return element;
    , mount);


    const deepest = createChildren(document.querySelector('#root'), arr);

    deepest.innerText = 'WebDevNSK'

    <div id="root"></div>





    var arr = ["ul", "li", "strong", "em", "u"];

    function createChildren(mount, arr)
    return arr.reduce((parent, elementName, i) =>
    const element = document.createElement(elementName);
    parent.appendChild(element);
    return element;
    , mount);


    const deepest = createChildren(document.querySelector('#root'), arr);

    deepest.innerText = 'WebDevNSK'

    <div id="root"></div>






    share|improve this answer














    share|improve this answer



    share|improve this answer








    edited 2 days ago









    Jack Bashford

    13.3k31847




    13.3k31847










    answered 2 days ago









    dangreendangreen

    1498




    1498












    • Seems like this is what I am looking for. I'll try to analyze it. And read about .reduce() Thank you btw.

      – Muyie
      2 days ago











    • What about => parent.appendChild(document.createElement(elementName));? Node.appendChild returns the appended child. However, readability is probably more important that concision.

      – Solomon Ucko
      2 days ago

















    • Seems like this is what I am looking for. I'll try to analyze it. And read about .reduce() Thank you btw.

      – Muyie
      2 days ago











    • What about => parent.appendChild(document.createElement(elementName));? Node.appendChild returns the appended child. However, readability is probably more important that concision.

      – Solomon Ucko
      2 days ago
















    Seems like this is what I am looking for. I'll try to analyze it. And read about .reduce() Thank you btw.

    – Muyie
    2 days ago





    Seems like this is what I am looking for. I'll try to analyze it. And read about .reduce() Thank you btw.

    – Muyie
    2 days ago













    What about => parent.appendChild(document.createElement(elementName));? Node.appendChild returns the appended child. However, readability is probably more important that concision.

    – Solomon Ucko
    2 days ago





    What about => parent.appendChild(document.createElement(elementName));? Node.appendChild returns the appended child. However, readability is probably more important that concision.

    – Solomon Ucko
    2 days ago











    0














    createDocumentFragment() and run the array through a loop. On each iteration createElement() and appendChild()






    const frag = document.createDocumentFragment();
    const useless = ["ul", "li", "strong", "em", "u"];

    let previous;
    for (let u = 0; u < useless.length; u++)
    const current = document.createElement(useless[u]);
    if (u === 0)
    frag.appendChild(current);
    else
    previous.appendChild(current);

    previous = current;


    document.body.appendChild(frag);

    ul 
    outline: 5px dashed green;
    padding: 15px;


    li
    outline: 5px solid blue;
    padding: 12px;


    strong
    outline: 5px dashed red;
    padding: 9px


    em
    outline: 5px dashed grey;
    padding: 6px


    u
    outline: 5px solid black;
    padding: 3px;


    u::before
    content: 'THIS TEXT SHOULD BE UNDERLINED'








    share|improve this answer



























      0














      createDocumentFragment() and run the array through a loop. On each iteration createElement() and appendChild()






      const frag = document.createDocumentFragment();
      const useless = ["ul", "li", "strong", "em", "u"];

      let previous;
      for (let u = 0; u < useless.length; u++)
      const current = document.createElement(useless[u]);
      if (u === 0)
      frag.appendChild(current);
      else
      previous.appendChild(current);

      previous = current;


      document.body.appendChild(frag);

      ul 
      outline: 5px dashed green;
      padding: 15px;


      li
      outline: 5px solid blue;
      padding: 12px;


      strong
      outline: 5px dashed red;
      padding: 9px


      em
      outline: 5px dashed grey;
      padding: 6px


      u
      outline: 5px solid black;
      padding: 3px;


      u::before
      content: 'THIS TEXT SHOULD BE UNDERLINED'








      share|improve this answer

























        0












        0








        0







        createDocumentFragment() and run the array through a loop. On each iteration createElement() and appendChild()






        const frag = document.createDocumentFragment();
        const useless = ["ul", "li", "strong", "em", "u"];

        let previous;
        for (let u = 0; u < useless.length; u++)
        const current = document.createElement(useless[u]);
        if (u === 0)
        frag.appendChild(current);
        else
        previous.appendChild(current);

        previous = current;


        document.body.appendChild(frag);

        ul 
        outline: 5px dashed green;
        padding: 15px;


        li
        outline: 5px solid blue;
        padding: 12px;


        strong
        outline: 5px dashed red;
        padding: 9px


        em
        outline: 5px dashed grey;
        padding: 6px


        u
        outline: 5px solid black;
        padding: 3px;


        u::before
        content: 'THIS TEXT SHOULD BE UNDERLINED'








        share|improve this answer













        createDocumentFragment() and run the array through a loop. On each iteration createElement() and appendChild()






        const frag = document.createDocumentFragment();
        const useless = ["ul", "li", "strong", "em", "u"];

        let previous;
        for (let u = 0; u < useless.length; u++)
        const current = document.createElement(useless[u]);
        if (u === 0)
        frag.appendChild(current);
        else
        previous.appendChild(current);

        previous = current;


        document.body.appendChild(frag);

        ul 
        outline: 5px dashed green;
        padding: 15px;


        li
        outline: 5px solid blue;
        padding: 12px;


        strong
        outline: 5px dashed red;
        padding: 9px


        em
        outline: 5px dashed grey;
        padding: 6px


        u
        outline: 5px solid black;
        padding: 3px;


        u::before
        content: 'THIS TEXT SHOULD BE UNDERLINED'








        const frag = document.createDocumentFragment();
        const useless = ["ul", "li", "strong", "em", "u"];

        let previous;
        for (let u = 0; u < useless.length; u++)
        const current = document.createElement(useless[u]);
        if (u === 0)
        frag.appendChild(current);
        else
        previous.appendChild(current);

        previous = current;


        document.body.appendChild(frag);

        ul 
        outline: 5px dashed green;
        padding: 15px;


        li
        outline: 5px solid blue;
        padding: 12px;


        strong
        outline: 5px dashed red;
        padding: 9px


        em
        outline: 5px dashed grey;
        padding: 6px


        u
        outline: 5px solid black;
        padding: 3px;


        u::before
        content: 'THIS TEXT SHOULD BE UNDERLINED'





        const frag = document.createDocumentFragment();
        const useless = ["ul", "li", "strong", "em", "u"];

        let previous;
        for (let u = 0; u < useless.length; u++)
        const current = document.createElement(useless[u]);
        if (u === 0)
        frag.appendChild(current);
        else
        previous.appendChild(current);

        previous = current;


        document.body.appendChild(frag);

        ul 
        outline: 5px dashed green;
        padding: 15px;


        li
        outline: 5px solid blue;
        padding: 12px;


        strong
        outline: 5px dashed red;
        padding: 9px


        em
        outline: 5px dashed grey;
        padding: 6px


        u
        outline: 5px solid black;
        padding: 3px;


        u::before
        content: 'THIS TEXT SHOULD BE UNDERLINED'






        share|improve this answer












        share|improve this answer



        share|improve this answer










        answered 2 days ago









        zer00nezer00ne

        25k32545




        25k32545



























            draft saved

            draft discarded
















































            Thanks for contributing an answer to Stack Overflow!


            • Please be sure to answer the question. Provide details and share your research!

            But avoid


            • Asking for help, clarification, or responding to other answers.

            • Making statements based on opinion; back them up with references or personal experience.

            To learn more, see our tips on writing great answers.




            draft saved


            draft discarded














            StackExchange.ready(
            function ()
            StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fstackoverflow.com%2fquestions%2f55311908%2fcreating-nested-elements-dynamically%23new-answer', 'question_page');

            );

            Post as a guest















            Required, but never shown





















































            Required, but never shown














            Required, but never shown












            Required, but never shown







            Required, but never shown

































            Required, but never shown














            Required, but never shown












            Required, but never shown







            Required, but never shown







            -dom, html, javascript

            Popular posts from this blog

            Identify plant with long narrow paired leaves and reddish stems Planned maintenance scheduled April 17/18, 2019 at 00:00UTC (8:00pm US/Eastern) Announcing the arrival of Valued Associate #679: Cesar Manara Unicorn Meta Zoo #1: Why another podcast?What is this plant with long sharp leaves? Is it a weed?What is this 3ft high, stalky plant, with mid sized narrow leaves?What is this young shrub with opposite ovate, crenate leaves and reddish stems?What is this plant with large broad serrated leaves?Identify this upright branching weed with long leaves and reddish stemsPlease help me identify this bulbous plant with long, broad leaves and white flowersWhat is this small annual with narrow gray/green leaves and rust colored daisy-type flowers?What is this chilli plant?Does anyone know what type of chilli plant this is?Help identify this plant

            fontconfig warning: “/etc/fonts/fonts.conf”, line 100: unknown “element blank” The 2019 Stack Overflow Developer Survey Results Are In“tar: unrecognized option --warning” during 'apt-get install'How to fix Fontconfig errorHow do I figure out which font file is chosen for a system generic font alias?Why are some apt-get-installed fonts being ignored by fc-list, xfontsel, etc?Reload settings in /etc/fonts/conf.dTaking 30 seconds longer to boot after upgrade from jessie to stretchHow to match multiple font names with a single <match> element?Adding a custom font to fontconfigRemoving fonts from fontconfig <match> resultsBroken fonts after upgrading Firefox ESR to latest Firefox

            Shilpa Shastras Contents Description In painting In carpentry In metallurgy Shilpa Shastra education in ancient India Treatises on Shilpa Shastras See also References Further reading External links Navigation menueOverviewTraditions of the Indian Craftsman251930242ŚilpinŚilpiniTraditions of the Indian CraftsmanThe Technique of Wall Painting in Ancient IndiaEssay on the Architecture of the HindusThe Journal of the Society of Arts10.1007/s11837-998-0378-3The role of India in the diffusion of early culturesTraditions of the Indian CraftsmanAn Encyclopedia of Hindu ArchitectureBibliography of Vastu Shastra Literature, 1834-2009The Technique of Wall Painting in Ancient India4483067Les lapidaires indiens