Windows user name variable and javascript

2019-06-09 18:14发布

问题:

I asked this question a few weeks ago and recently came back to it and solved it. I have a hidden input that looks like this:

                <input style="display:none;" class="fileDialog" type="file" nwworkingdir="C:\Users\" nwsaveas/>

This opens a save dialog at the dir given to nwworkingdir. I would like the default location to be the user's Pictures directory but I am having trouble getting the system user name dynamically with javascript. I need the username because the path is usually C:\Users\USERNAME\Pictures. I have tried constants such asssfMYPICTURESandCSIDL_PROFILE` but javascript doesn't recognize them or I am using them wrong.

The project is in node-webkit so a solution using javascript, node.js, or node-webkit APIs should work.

回答1:

Solution for future readers:

Node.js function in "screen_shot.js":

exports.getUserHome = function() {
    return process.env[(process.platform == 'win32') ? 'USERPROFILE' : 'HOME'];
}

header js in index.html:

   $(document).ready(function() {
       var sc= require('screen_shot');
       $('.fileDialog').each(function(i) {
           $(this).attr('nwworkingdir', sc.getUserHome() + '\\Pictures');
       });
   });

                var sc= require('screen_shot');
            function wait(e) {
                var page = $(e).closest('[data-role="page"]');
                $('#close-popup').click();
                page.find('.fileDialog').click();
            }

            function screen_shot(fn) {
                html2canvas($('body'), {
                    onrendered: function(canvas) {
                    var img = canvas.toDataURL("image/png").split(',')[1];
                    sc.buildFile(fn, img);
                  }
                });
            }

            $('["..."]').live("pagecreate", function() {
                $(this).find('.fileDialog').change(function() {screen_shot($('.fileDialog').val() + '.png');});
            });

            $('[id^="..."]').live("pagecreate", function() {
                $(this).find('.fileDialog').change(function() {screen_shot($('.fileDialog').val() + '.png');});
            });

            $('[id^="..."]').live("pagecreate", function() {
                $(this).find('.fileDialog').change(function() {screen_shot($('.fileDialog').val() + '.png');});
            });

dialog and button:

                <input style="display:none;" class="fileDialog" type="file" nwworkingdir="" nwsaveas/>
                <a href="#" onclick="wait(this);" data-role="button" data-theme="j">Save As</a>